* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-06-08 17:03 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-06-08 17:03 UTC (permalink / raw
  To: gentoo-commits
commit:     57f0631d613835def90f12c998feef13b5b7d629
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  8 17:02:35 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  8 17:02:35 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=57f0631d
15.0.0: drop 76_all_ppc_PR112868-no-checking-many.patch
Drop 76_all_ppc_PR112868-no-checking-many.patch because of
https://gcc.gnu.org/PR113652.
Bug: https://gcc.gnu.org/PR112868
Bug: https://gcc.gnu.org/PR113652
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../76_all_ppc_PR112868-no-checking-many.patch     | 42 ----------------------
 15.0.0/gentoo/README.history                       |  5 +++
 2 files changed, 5 insertions(+), 42 deletions(-)
diff --git a/15.0.0/gentoo/76_all_ppc_PR112868-no-checking-many.patch b/15.0.0/gentoo/76_all_ppc_PR112868-no-checking-many.patch
deleted file mode 100644
index dc9f5e5..0000000
--- a/15.0.0/gentoo/76_all_ppc_PR112868-no-checking-many.patch
+++ /dev/null
@@ -1,42 +0,0 @@
-https://gcc.gnu.org/PR112868 (specifically https://gcc.gnu.org/bugzilla/show_bug.cgi?id=112868#c8)
-(see also https://gcc.gnu.org/PR113652)
-
---- a/gcc/config/rs6000/rs6000.h
-+++ b/gcc/config/rs6000/rs6000.h
-@@ -94,12 +94,6 @@
-   "%{mdejagnu-*: %<mdejagnu-*}", \
-    SUBTARGET_DRIVER_SELF_SPECS
- 
--#if CHECKING_P
--#define ASM_OPT_ANY ""
--#else
--#define ASM_OPT_ANY " -many"
--#endif
--
- /* Common ASM definitions used by ASM_SPEC among the various targets for
-    handling -mcpu=xxx switches.  There is a parallel list in driver-rs6000.cc to
-    provide the default assembler options if the user uses -mcpu=native, so if
-@@ -166,8 +160,7 @@
- 	    mvsx: -mpower7; \
- 	    mpowerpc64: -mppc64;: %(asm_default)}; \
-   :%eMissing -mcpu option in ASM_CPU_SPEC?\n} \
--%{mvsx: -mvsx -maltivec; maltivec: -maltivec}" \
--ASM_OPT_ANY
-+%{mvsx: -mvsx -maltivec; maltivec: -maltivec}"
- 
- #define CPP_DEFAULT_SPEC ""
- 
---- a/gcc/testsuite/lib/target-supports.exp
-+++ b/gcc/testsuite/lib/target-supports.exp
-@@ -7285,7 +7285,7 @@ proc check_effective_target_powerpc_ppu_ok { } {
- #endif
- 		return 0;
- 	    }
--	}]
-+	} "-mcpu=cell"]
-     } else {
- 	return 0
-     }
-
-
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 926ce25..15054c4 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,8 @@
+2	????
+
+	- 76_all_ppc_PR112868-no-checking-many.patch
+
+
 1	28 Apr 2024
 
 	+ 01_all_default-fortify-source.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-06-08 17:03 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-06-08 17:03 UTC (permalink / raw
  To: gentoo-commits
commit:     ab342368b9d0d2ac7f249ca2240644940c51fa78
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  8 17:03:05 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  8 17:03:19 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ab342368
15.0.0: add 76_all_ppc_PR97367-power7-cell-altivec.patch
Requested by ernsteiswuerfel.
Bug: https://gcc.gnu.org/PR97367
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/76_all_ppc_PR97367-power7-cell-altivec.patch | 13 +++++++++++++
 15.0.0/gentoo/README.history                               |  2 +-
 2 files changed, 14 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/76_all_ppc_PR97367-power7-cell-altivec.patch b/15.0.0/gentoo/76_all_ppc_PR97367-power7-cell-altivec.patch
new file mode 100644
index 0000000..154dd0f
--- /dev/null
+++ b/15.0.0/gentoo/76_all_ppc_PR97367-power7-cell-altivec.patch
@@ -0,0 +1,13 @@
+https://gcc.gnu.org/PR97367
+https://inbox.sourceware.org/gcc-patches/20240308.123342.1112119677226246836.rene@exactcode.de/
+--- a/gcc/config/rs6000/rs6000.cc
++++ b/gcc/config/rs6000/rs6000.cc
+@@ -5869,7 +5869,7 @@ rs6000_machine_from_flags (void)
+   HOST_WIDE_INT flags = rs6000_isa_flags;
+ 
+   /* Disable the flags that should never influence the .machine selection.  */
+-  flags &= ~(OPTION_MASK_PPC_GFXOPT | OPTION_MASK_PPC_GPOPT | OPTION_MASK_ISEL);
++  flags &= ~(OPTION_MASK_PPC_GFXOPT | OPTION_MASK_PPC_GPOPT | OPTION_MASK_ALTIVEC | OPTION_MASK_ISEL);
+ 
+   if ((flags & (ISA_3_1_MASKS_SERVER & ~ISA_3_0_MASKS_SERVER)) != 0)
+     return "power10";
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 15054c4..32feb0a 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,7 +1,7 @@
 2	????
 
 	- 76_all_ppc_PR112868-no-checking-many.patch
-
+	+ 76_all_ppc_PR97367-power7-cell-altivec.patch
 
 1	28 Apr 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-06-10  2:08 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-06-10  2:08 UTC (permalink / raw
  To: gentoo-commits
commit:     6fd8b4c1269795b281ede03ea1e9cd6ed3df1585
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 10 02:05:55 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 10 02:07:30 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=6fd8b4c1
15.0.0: cut patchset 2
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 32feb0a..b2b3de3 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-2	????
+2	10 June 2024
 
 	- 76_all_ppc_PR112868-no-checking-many.patch
 	+ 76_all_ppc_PR97367-power7-cell-altivec.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-06-10 17:28 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-06-10 17:28 UTC (permalink / raw
  To: gentoo-commits
commit:     75e80ce24ee1b7a17c13e9e513cab5ba81635262
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 10 17:25:14 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 10 17:25:14 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=75e80ce2
15.0.0: backport two fixes
A severe miscompilation and a severe ICE fix.
Bug: https://gcc.gnu.org/PR115387
Bug: https://gcc.gnu.org/PR115395
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/77_all_PR115387.patch | 206 ++++++++++++++++++++++++++++++++++++
 15.0.0/gentoo/78_all_PR115395.patch | 107 +++++++++++++++++++
 15.0.0/gentoo/README.history        |   5 +
 3 files changed, 318 insertions(+)
diff --git a/15.0.0/gentoo/77_all_PR115387.patch b/15.0.0/gentoo/77_all_PR115387.patch
new file mode 100644
index 0000000..bf143e7
--- /dev/null
+++ b/15.0.0/gentoo/77_all_PR115387.patch
@@ -0,0 +1,206 @@
+https://gcc.gnu.org/PR115387
+https://inbox.sourceware.org/gcc-patches/430da3ad-59a6-4f16-b35f-8bef724a7ed7@gmail.com/T/#t
+
+From mboxrd@z Thu Jan  1 00:00:00 1970
+Return-Path: <SRS0=SYw7=NM=intel.com=pan2.li@sourceware.org>
+Received: from mgamail.intel.com (mgamail.intel.com [198.175.65.14])
+	by sourceware.org (Postfix) with ESMTPS id 48A883858CDB
+	for <gcc-patches@gcc.gnu.org>; Mon, 10 Jun 2024 14:49:07 +0000 (GMT)
+DMARC-Filter: OpenDMARC Filter v1.4.2 sourceware.org 48A883858CDB
+Authentication-Results: sourceware.org; dmarc=pass (p=none dis=none) header.from=intel.com
+Authentication-Results: sourceware.org; spf=pass smtp.mailfrom=intel.com
+ARC-Filter: OpenARC Filter v1.0.0 sourceware.org 48A883858CDB
+Authentication-Results: server2.sourceware.org; arc=none smtp.remote-ip=198.175.65.14
+ARC-Seal: i=1; a=rsa-sha256; d=sourceware.org; s=key; t=1718030949; cv=none;
+	b=sYMAFxaXXHzkHsYoFI0HFGXWzujiQRXs1KA4PpQKerabnFz185hAazNZgv5HRn33NHy30a6CaFSGdNqMzI5rJ/uWP0t/IVSZPws+DkO9GCBPkgQLIHvRRf5J+uf7usxHf+quk0tjfzrDkHctT7riGqQjzSEAkBTwrKXd7X9aQ9k=
+ARC-Message-Signature: i=1; a=rsa-sha256; d=sourceware.org; s=key;
+	t=1718030949; c=relaxed/simple;
+	bh=p/hDLfesLAxds7UkloKeUvZGINWc0ydc/cnr4ptMBSU=;
+	h=DKIM-Signature:From:To:Subject:Date:Message-Id:MIME-Version; b=GtE3ODQcVtLdsf2+edm43ZWyfgTSrruAj3RQ1zIcTMeifKot7fY59t2YIAFrSyx/vKLMuPwocIQ8p3VmYLj4DB2f8ybXvEhBcx2pxlh5GNVmPxjGtJsnrv6p7oMG9CA6X/bns8vlMhr2CgwzHRba7bItkwFWjKkI8gbJz3v9zeo=
+ARC-Authentication-Results: i=1; server2.sourceware.org
+DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple;
+  d=intel.com; i=@intel.com; q=dns/txt; s=Intel;
+  t=1718030948; x=1749566948;
+  h=from:to:cc:subject:date:message-id:mime-version:
+   content-transfer-encoding;
+  bh=p/hDLfesLAxds7UkloKeUvZGINWc0ydc/cnr4ptMBSU=;
+  b=biitKQIpbkCUKRo31CQVWz5tQ3QP6AsTulnDi3LB7cDTMJflku4VDWDx
+   Dnu97Pvn/2HzgfrZyN+1kVfGvLnehrErvG2qw3kZ2PGu0AiKrtnTRj0ED
+   UdyWa4+MQF5nj34UK92MRcA1Ovou3O89YdQ11EmVuL1KynSTtKgwo/d/9
+   JsYn3MkWZP6NjVgZteOu5xBZF+J3NxK61azjaUgP8LIxo1bmEKUMBgo0f
+   p0gXtZXjZkxtpcqzr++CtB6e4fKUHQK8z/FjOzaHvwIzmxdoEcptRGtl9
+   v+2kXKMcvMQGZZlsBfFIewmNKjK6qUYGrDKl1wltMZMkeijuudmObyhaq
+   A==;
+X-CSE-ConnectionGUID: JaJ1NR5jSimBRrZvjuM+Lw==
+X-CSE-MsgGUID: Q6rSZfGaQfOHvXT9LPs02g==
+X-IronPort-AV: E=McAfee;i="6600,9927,11099"; a="18526139"
+X-IronPort-AV: E=Sophos;i="6.08,227,1712646000"; 
+   d="scan'208";a="18526139"
+Received: from orviesa002.jf.intel.com ([10.64.159.142])
+  by orvoesa106.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 10 Jun 2024 07:49:07 -0700
+X-CSE-ConnectionGUID: +SJ6B8QPQfWwhjgjPJujEw==
+X-CSE-MsgGUID: eHhYmO22SKyPWaJe7LW77Q==
+X-ExtLoop1: 1
+X-IronPort-AV: E=Sophos;i="6.08,227,1712646000"; 
+   d="scan'208";a="69872329"
+Received: from shvmail03.sh.intel.com ([10.239.245.20])
+  by orviesa002.jf.intel.com with ESMTP; 10 Jun 2024 07:49:04 -0700
+Received: from pli-ubuntu.sh.intel.com (pli-ubuntu.sh.intel.com [10.239.159.47])
+	by shvmail03.sh.intel.com (Postfix) with ESMTP id E43A71007C1D;
+	Mon, 10 Jun 2024 22:49:02 +0800 (CST)
+From: pan2.li@intel.com
+To: gcc-patches@gcc.gnu.org
+Cc: juzhe.zhong@rivai.ai,
+	kito.cheng@gmail.com,
+	richard.guenther@gmail.com,
+	Pan Li <pan2.li@intel.com>
+Subject: [PATCH v1] Widening-Mul: Fix one ICE of gcall insertion for PHI match
+Date: Mon, 10 Jun 2024 22:49:01 +0800
+Message-Id: <20240610144901.3723532-1-pan2.li@intel.com>
+X-Mailer: git-send-email 2.34.1
+MIME-Version: 1.0
+Content-Transfer-Encoding: 8bit
+X-Spam-Status: No, score=-11.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH,DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,GIT_PATCH_0,KAM_SHORT,SPF_HELO_NONE,SPF_NONE,TXREP,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6
+X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on server2.sourceware.org
+List-Id: <gcc-patches.gcc.gnu.org>
+
+From: Pan Li <pan2.li@intel.com>
+
+When enabled the PHI handing for COND_EXPR,  we need to insert the gcall
+to replace the PHI node.  Unfortunately,  I made a mistake that insert
+the gcall to before the last stmt of the bb.  See below gimple,  the PHI
+is located at no.1 but we insert the gcall (aka no.9) to the end of
+the bb.  Then the use of _9 in no.2 will have no def and will trigger
+ICE when verify_ssa.
+
+  1. # _9 = PHI <_3(4), 18446744073709551615(3)> // The PHI node to be deleted.
+  2. prephitmp_36 = (char *) _9;
+  3. buf.write_base = string_13(D);
+  4. buf.write_ptr = string_13(D);
+  5. buf.write_end = prephitmp_36;
+  6. buf.written = 0;
+  7. buf.mode = 3;
+  8. _7 = buf.write_end;
+  9. _9 = .SAT_ADD (string.0_2, maxlen_15(D));   // Insert gcall to last bb by mistake
+
+This patch would like to insert the gcall to before the start of the bb
+stmt.  To ensure the possible use of PHI_result will have a def exists.
+After this patch the above gimple will be:
+
+  0. _9 = .SAT_ADD (string.0_2, maxlen_15(D));   // Insert gcall to start bb by mistake
+  1. # _9 = PHI <_3(4), 18446744073709551615(3)> // The PHI node to be deleted.
+  2. prephitmp_36 = (char *) _9;
+  3. buf.write_base = string_13(D);
+  4. buf.write_ptr = string_13(D);
+  5. buf.write_end = prephitmp_36;
+  6. buf.written = 0;
+  7. buf.mode = 3;
+  8. _7 = buf.write_end;
+
+The below test suites are passed for this patch:
+* The rv64gcv fully regression test with newlib.
+* The rv64gcv build with glibc.
+* The x86 regression test with newlib.
+* The x86 bootstrap test with newlib.
+
+	PR target/115387
+
+gcc/ChangeLog:
+
+	* tree-ssa-math-opts.cc (math_opts_dom_walker::after_dom_children): Take
+	the gsi of start_bb instead of last_bb.
+
+gcc/testsuite/ChangeLog:
+
+	* gcc.target/riscv/pr115387-1.c: New test.
+	* gcc.target/riscv/pr115387-2.c: New test.
+
+Signed-off-by: Pan Li <pan2.li@intel.com>
+---
+ gcc/testsuite/gcc.target/riscv/pr115387-1.c | 35 +++++++++++++++++++++
+ gcc/testsuite/gcc.target/riscv/pr115387-2.c | 18 +++++++++++
+ gcc/tree-ssa-math-opts.cc                   |  2 +-
+ 3 files changed, 54 insertions(+), 1 deletion(-)
+ create mode 100644 gcc/testsuite/gcc.target/riscv/pr115387-1.c
+ create mode 100644 gcc/testsuite/gcc.target/riscv/pr115387-2.c
+
+diff --git a/gcc/testsuite/gcc.target/riscv/pr115387-1.c b/gcc/testsuite/gcc.target/riscv/pr115387-1.c
+new file mode 100644
+index 00000000000..a1c926977c4
+--- /dev/null
++++ b/gcc/testsuite/gcc.target/riscv/pr115387-1.c
+@@ -0,0 +1,35 @@
++/* Test there is no ICE when compile.  */
++/* { dg-do compile } */
++/* { dg-options "-march=rv64gcv -mabi=lp64d -O3" } */
++
++#define PRINTF_CHK 0x34
++
++typedef unsigned long uintptr_t;
++
++struct __printf_buffer {
++  char *write_ptr;
++  int status;
++};
++
++extern void __printf_buffer_init_end (struct __printf_buffer *, char *, char *);
++
++void
++test (char *string, unsigned long maxlen, unsigned mode_flags)
++{
++  struct __printf_buffer buf;
++
++  if ((mode_flags & PRINTF_CHK) != 0)
++    {
++      string[0] = '\0';
++      uintptr_t end;
++
++      if (__builtin_add_overflow ((uintptr_t) string, maxlen, &end))
++	end = -1;
++
++      __printf_buffer_init_end (&buf, string, (char *) end);
++    }
++  else
++    __printf_buffer_init_end (&buf, string, (char *) ~(uintptr_t) 0);
++
++  *buf.write_ptr = '\0';
++}
+diff --git a/gcc/testsuite/gcc.target/riscv/pr115387-2.c b/gcc/testsuite/gcc.target/riscv/pr115387-2.c
+new file mode 100644
+index 00000000000..7183bf18dfd
+--- /dev/null
++++ b/gcc/testsuite/gcc.target/riscv/pr115387-2.c
+@@ -0,0 +1,18 @@
++/* Test there is no ICE when compile.  */
++/* { dg-do compile } */
++/* { dg-options "-march=rv64gcv -mabi=lp64d -O3" } */
++
++#include <stddef.h>
++#include <stdint-gcc.h>
++
++char *
++test (char *string, size_t maxlen)
++{
++  string[0] = '\0';
++  uintptr_t end;
++
++  if (__builtin_add_overflow ((uintptr_t) string, maxlen, &end))
++    end = -1;
++
++  return (char *) end;
++}
+diff --git a/gcc/tree-ssa-math-opts.cc b/gcc/tree-ssa-math-opts.cc
+index 173b0366f5e..fbb8e0ea306 100644
+--- a/gcc/tree-ssa-math-opts.cc
++++ b/gcc/tree-ssa-math-opts.cc
+@@ -6102,7 +6102,7 @@ math_opts_dom_walker::after_dom_children (basic_block bb)
+   for (gphi_iterator psi = gsi_start_phis (bb); !gsi_end_p (psi);
+     gsi_next (&psi))
+     {
+-      gimple_stmt_iterator gsi = gsi_last_bb (bb);
++      gimple_stmt_iterator gsi = gsi_start_bb (bb);
+       match_unsigned_saturation_add (&gsi, psi.phi ());
+     }
+ 
+-- 
+2.34.1
diff --git a/15.0.0/gentoo/78_all_PR115395.patch b/15.0.0/gentoo/78_all_PR115395.patch
new file mode 100644
index 0000000..d98c043
--- /dev/null
+++ b/15.0.0/gentoo/78_all_PR115395.patch
@@ -0,0 +1,107 @@
+https://gcc.gnu.org/PR115395
+
+From 4ed9c5df7efeb98e190573cca42a4fd40666c45f Mon Sep 17 00:00:00 2001
+From: Richard Biener <rguenther@suse.de>
+Date: Mon, 10 Jun 2024 10:12:52 +0200
+Subject: [PATCH] tree-optimization/115395 - wrong-code with SLP reduction in
+ epilog
+
+When we continue a non-SLP reduction from the main loop in the
+epilog with a SLP reduction we currently fail to handle an
+adjustment by the initial value because that's not a thing with SLP.
+As long as we have the possibility to mix SLP and non-SLP we have
+to handle it though.
+
+	PR tree-optimization/115395
+	* tree-vect-loop.cc (vect_create_epilog_for_reduction):
+	Handle STMT_VINFO_REDUC_EPILOGUE_ADJUSTMENT also for SLP
+	reductions of group_size one.
+
+	* gcc.dg/vect/pr115395.c: New testcase.
+---
+ gcc/testsuite/gcc.dg/vect/pr115395.c | 27 +++++++++++++++++++++++++++
+ gcc/tree-vect-loop.cc                | 27 ++++++++-------------------
+ 2 files changed, 35 insertions(+), 19 deletions(-)
+ create mode 100644 gcc/testsuite/gcc.dg/vect/pr115395.c
+
+diff --git a/gcc/testsuite/gcc.dg/vect/pr115395.c b/gcc/testsuite/gcc.dg/vect/pr115395.c
+new file mode 100644
+index 00000000000..cd1cee9f3df
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/vect/pr115395.c
+@@ -0,0 +1,27 @@
++/* { dg-additional-options "-mavx2" { target avx2_runtime } } */
++
++#include "tree-vect.h"
++
++struct {
++  long header_size;
++  long start_offset;
++  long end_offset;
++} myrar_dbo[5] = {{0, 87, 6980}, {0, 7087, 13980}, {0, 14087, 0}};
++
++int i;
++long offset;
++
++int main()
++{
++  check_vect ();
++
++  offset += myrar_dbo[0].start_offset;
++  while (i < 2) {
++    i++;
++    offset += myrar_dbo[i].start_offset - myrar_dbo[i - 1].end_offset;
++  }
++  if (offset != 301)
++    abort();
++
++  return 0;
++}
+diff --git a/gcc/tree-vect-loop.cc b/gcc/tree-vect-loop.cc
+index 028692614bb..c471f1564a7 100644
+--- a/gcc/tree-vect-loop.cc
++++ b/gcc/tree-vect-loop.cc
+@@ -6030,25 +6030,14 @@ vect_create_epilog_for_reduction (loop_vec_info loop_vinfo,
+ 
+   tree induc_val = NULL_TREE;
+   tree adjustment_def = NULL;
+-  if (slp_node)
+-    {
+-      /* Optimize: for induction condition reduction, if we can't use zero
+-	 for induc_val, use initial_def.  */
+-      if (STMT_VINFO_REDUC_TYPE (reduc_info) == INTEGER_INDUC_COND_REDUCTION)
+-	induc_val = STMT_VINFO_VEC_INDUC_COND_INITIAL_VAL (reduc_info);
+-      /* ???  Coverage for 'else' isn't clear.  */
+-    }
++  /* Optimize: for induction condition reduction, if we can't use zero
++     for induc_val, use initial_def.  */
++  if (STMT_VINFO_REDUC_TYPE (reduc_info) == INTEGER_INDUC_COND_REDUCTION)
++    induc_val = STMT_VINFO_VEC_INDUC_COND_INITIAL_VAL (reduc_info);
++  else if (double_reduc)
++    ;
+   else
+-    {
+-      /* Optimize: for induction condition reduction, if we can't use zero
+-         for induc_val, use initial_def.  */
+-      if (STMT_VINFO_REDUC_TYPE (reduc_info) == INTEGER_INDUC_COND_REDUCTION)
+-	induc_val = STMT_VINFO_VEC_INDUC_COND_INITIAL_VAL (reduc_info);
+-      else if (double_reduc)
+-	;
+-      else
+-	adjustment_def = STMT_VINFO_REDUC_EPILOGUE_ADJUSTMENT (reduc_info);
+-    }
++    adjustment_def = STMT_VINFO_REDUC_EPILOGUE_ADJUSTMENT (reduc_info);
+ 
+   stmt_vec_info single_live_out_stmt[] = { stmt_info };
+   array_slice<const stmt_vec_info> live_out_stmts = single_live_out_stmt;
+@@ -6873,7 +6862,7 @@ vect_create_epilog_for_reduction (loop_vec_info loop_vinfo,
+ 
+   if (adjustment_def)
+     {
+-      gcc_assert (!slp_reduc);
++      gcc_assert (!slp_reduc || group_size == 1);
+       gimple_seq stmts = NULL;
+       if (double_reduc)
+ 	{
+-- 
+2.43.0
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index b2b3de3..1573b55 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,8 @@
+3	10 June 2024
+
+	+ 77_all_PR115387.patch
+	+ 78_all_PR115395.patch
+
 2	10 June 2024
 
 	- 76_all_ppc_PR112868-no-checking-many.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-06-10 17:28 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-06-10 17:28 UTC (permalink / raw
  To: gentoo-commits
commit:     98503e61e8b723a012ccef2eed6a8387e43535e7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 10 17:28:02 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 10 17:28:02 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=98503e61
15.0.0: drop upstreamed patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/78_all_PR115395.patch | 107 ------------------------------------
 15.0.0/gentoo/README.history        |   4 ++
 2 files changed, 4 insertions(+), 107 deletions(-)
diff --git a/15.0.0/gentoo/78_all_PR115395.patch b/15.0.0/gentoo/78_all_PR115395.patch
deleted file mode 100644
index d98c043..0000000
--- a/15.0.0/gentoo/78_all_PR115395.patch
+++ /dev/null
@@ -1,107 +0,0 @@
-https://gcc.gnu.org/PR115395
-
-From 4ed9c5df7efeb98e190573cca42a4fd40666c45f Mon Sep 17 00:00:00 2001
-From: Richard Biener <rguenther@suse.de>
-Date: Mon, 10 Jun 2024 10:12:52 +0200
-Subject: [PATCH] tree-optimization/115395 - wrong-code with SLP reduction in
- epilog
-
-When we continue a non-SLP reduction from the main loop in the
-epilog with a SLP reduction we currently fail to handle an
-adjustment by the initial value because that's not a thing with SLP.
-As long as we have the possibility to mix SLP and non-SLP we have
-to handle it though.
-
-	PR tree-optimization/115395
-	* tree-vect-loop.cc (vect_create_epilog_for_reduction):
-	Handle STMT_VINFO_REDUC_EPILOGUE_ADJUSTMENT also for SLP
-	reductions of group_size one.
-
-	* gcc.dg/vect/pr115395.c: New testcase.
----
- gcc/testsuite/gcc.dg/vect/pr115395.c | 27 +++++++++++++++++++++++++++
- gcc/tree-vect-loop.cc                | 27 ++++++++-------------------
- 2 files changed, 35 insertions(+), 19 deletions(-)
- create mode 100644 gcc/testsuite/gcc.dg/vect/pr115395.c
-
-diff --git a/gcc/testsuite/gcc.dg/vect/pr115395.c b/gcc/testsuite/gcc.dg/vect/pr115395.c
-new file mode 100644
-index 00000000000..cd1cee9f3df
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/vect/pr115395.c
-@@ -0,0 +1,27 @@
-+/* { dg-additional-options "-mavx2" { target avx2_runtime } } */
-+
-+#include "tree-vect.h"
-+
-+struct {
-+  long header_size;
-+  long start_offset;
-+  long end_offset;
-+} myrar_dbo[5] = {{0, 87, 6980}, {0, 7087, 13980}, {0, 14087, 0}};
-+
-+int i;
-+long offset;
-+
-+int main()
-+{
-+  check_vect ();
-+
-+  offset += myrar_dbo[0].start_offset;
-+  while (i < 2) {
-+    i++;
-+    offset += myrar_dbo[i].start_offset - myrar_dbo[i - 1].end_offset;
-+  }
-+  if (offset != 301)
-+    abort();
-+
-+  return 0;
-+}
-diff --git a/gcc/tree-vect-loop.cc b/gcc/tree-vect-loop.cc
-index 028692614bb..c471f1564a7 100644
---- a/gcc/tree-vect-loop.cc
-+++ b/gcc/tree-vect-loop.cc
-@@ -6030,25 +6030,14 @@ vect_create_epilog_for_reduction (loop_vec_info loop_vinfo,
- 
-   tree induc_val = NULL_TREE;
-   tree adjustment_def = NULL;
--  if (slp_node)
--    {
--      /* Optimize: for induction condition reduction, if we can't use zero
--	 for induc_val, use initial_def.  */
--      if (STMT_VINFO_REDUC_TYPE (reduc_info) == INTEGER_INDUC_COND_REDUCTION)
--	induc_val = STMT_VINFO_VEC_INDUC_COND_INITIAL_VAL (reduc_info);
--      /* ???  Coverage for 'else' isn't clear.  */
--    }
-+  /* Optimize: for induction condition reduction, if we can't use zero
-+     for induc_val, use initial_def.  */
-+  if (STMT_VINFO_REDUC_TYPE (reduc_info) == INTEGER_INDUC_COND_REDUCTION)
-+    induc_val = STMT_VINFO_VEC_INDUC_COND_INITIAL_VAL (reduc_info);
-+  else if (double_reduc)
-+    ;
-   else
--    {
--      /* Optimize: for induction condition reduction, if we can't use zero
--         for induc_val, use initial_def.  */
--      if (STMT_VINFO_REDUC_TYPE (reduc_info) == INTEGER_INDUC_COND_REDUCTION)
--	induc_val = STMT_VINFO_VEC_INDUC_COND_INITIAL_VAL (reduc_info);
--      else if (double_reduc)
--	;
--      else
--	adjustment_def = STMT_VINFO_REDUC_EPILOGUE_ADJUSTMENT (reduc_info);
--    }
-+    adjustment_def = STMT_VINFO_REDUC_EPILOGUE_ADJUSTMENT (reduc_info);
- 
-   stmt_vec_info single_live_out_stmt[] = { stmt_info };
-   array_slice<const stmt_vec_info> live_out_stmts = single_live_out_stmt;
-@@ -6873,7 +6862,7 @@ vect_create_epilog_for_reduction (loop_vec_info loop_vinfo,
- 
-   if (adjustment_def)
-     {
--      gcc_assert (!slp_reduc);
-+      gcc_assert (!slp_reduc || group_size == 1);
-       gimple_seq stmts = NULL;
-       if (double_reduc)
- 	{
--- 
-2.43.0
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 1573b55..81ca552 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+4	????
+
+	- 78_all_PR115395.patch
+
 3	10 June 2024
 
 	+ 77_all_PR115387.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-06-10 20:18 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-06-10 20:18 UTC (permalink / raw
  To: gentoo-commits
commit:     c8bf41759fe849050fcb5c5105483c9db6b15da2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 10 20:18:07 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 10 20:18:07 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=c8bf4175
15.0.0: drop upstream 77_all_PR115387.patch
It got merged.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/77_all_PR115387.patch | 206 ------------------------------------
 15.0.0/gentoo/README.history        |   1 +
 2 files changed, 1 insertion(+), 206 deletions(-)
diff --git a/15.0.0/gentoo/77_all_PR115387.patch b/15.0.0/gentoo/77_all_PR115387.patch
deleted file mode 100644
index bf143e7..0000000
--- a/15.0.0/gentoo/77_all_PR115387.patch
+++ /dev/null
@@ -1,206 +0,0 @@
-https://gcc.gnu.org/PR115387
-https://inbox.sourceware.org/gcc-patches/430da3ad-59a6-4f16-b35f-8bef724a7ed7@gmail.com/T/#t
-
-From mboxrd@z Thu Jan  1 00:00:00 1970
-Return-Path: <SRS0=SYw7=NM=intel.com=pan2.li@sourceware.org>
-Received: from mgamail.intel.com (mgamail.intel.com [198.175.65.14])
-	by sourceware.org (Postfix) with ESMTPS id 48A883858CDB
-	for <gcc-patches@gcc.gnu.org>; Mon, 10 Jun 2024 14:49:07 +0000 (GMT)
-DMARC-Filter: OpenDMARC Filter v1.4.2 sourceware.org 48A883858CDB
-Authentication-Results: sourceware.org; dmarc=pass (p=none dis=none) header.from=intel.com
-Authentication-Results: sourceware.org; spf=pass smtp.mailfrom=intel.com
-ARC-Filter: OpenARC Filter v1.0.0 sourceware.org 48A883858CDB
-Authentication-Results: server2.sourceware.org; arc=none smtp.remote-ip=198.175.65.14
-ARC-Seal: i=1; a=rsa-sha256; d=sourceware.org; s=key; t=1718030949; cv=none;
-	b=sYMAFxaXXHzkHsYoFI0HFGXWzujiQRXs1KA4PpQKerabnFz185hAazNZgv5HRn33NHy30a6CaFSGdNqMzI5rJ/uWP0t/IVSZPws+DkO9GCBPkgQLIHvRRf5J+uf7usxHf+quk0tjfzrDkHctT7riGqQjzSEAkBTwrKXd7X9aQ9k=
-ARC-Message-Signature: i=1; a=rsa-sha256; d=sourceware.org; s=key;
-	t=1718030949; c=relaxed/simple;
-	bh=p/hDLfesLAxds7UkloKeUvZGINWc0ydc/cnr4ptMBSU=;
-	h=DKIM-Signature:From:To:Subject:Date:Message-Id:MIME-Version; b=GtE3ODQcVtLdsf2+edm43ZWyfgTSrruAj3RQ1zIcTMeifKot7fY59t2YIAFrSyx/vKLMuPwocIQ8p3VmYLj4DB2f8ybXvEhBcx2pxlh5GNVmPxjGtJsnrv6p7oMG9CA6X/bns8vlMhr2CgwzHRba7bItkwFWjKkI8gbJz3v9zeo=
-ARC-Authentication-Results: i=1; server2.sourceware.org
-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple;
-  d=intel.com; i=@intel.com; q=dns/txt; s=Intel;
-  t=1718030948; x=1749566948;
-  h=from:to:cc:subject:date:message-id:mime-version:
-   content-transfer-encoding;
-  bh=p/hDLfesLAxds7UkloKeUvZGINWc0ydc/cnr4ptMBSU=;
-  b=biitKQIpbkCUKRo31CQVWz5tQ3QP6AsTulnDi3LB7cDTMJflku4VDWDx
-   Dnu97Pvn/2HzgfrZyN+1kVfGvLnehrErvG2qw3kZ2PGu0AiKrtnTRj0ED
-   UdyWa4+MQF5nj34UK92MRcA1Ovou3O89YdQ11EmVuL1KynSTtKgwo/d/9
-   JsYn3MkWZP6NjVgZteOu5xBZF+J3NxK61azjaUgP8LIxo1bmEKUMBgo0f
-   p0gXtZXjZkxtpcqzr++CtB6e4fKUHQK8z/FjOzaHvwIzmxdoEcptRGtl9
-   v+2kXKMcvMQGZZlsBfFIewmNKjK6qUYGrDKl1wltMZMkeijuudmObyhaq
-   A==;
-X-CSE-ConnectionGUID: JaJ1NR5jSimBRrZvjuM+Lw==
-X-CSE-MsgGUID: Q6rSZfGaQfOHvXT9LPs02g==
-X-IronPort-AV: E=McAfee;i="6600,9927,11099"; a="18526139"
-X-IronPort-AV: E=Sophos;i="6.08,227,1712646000"; 
-   d="scan'208";a="18526139"
-Received: from orviesa002.jf.intel.com ([10.64.159.142])
-  by orvoesa106.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 10 Jun 2024 07:49:07 -0700
-X-CSE-ConnectionGUID: +SJ6B8QPQfWwhjgjPJujEw==
-X-CSE-MsgGUID: eHhYmO22SKyPWaJe7LW77Q==
-X-ExtLoop1: 1
-X-IronPort-AV: E=Sophos;i="6.08,227,1712646000"; 
-   d="scan'208";a="69872329"
-Received: from shvmail03.sh.intel.com ([10.239.245.20])
-  by orviesa002.jf.intel.com with ESMTP; 10 Jun 2024 07:49:04 -0700
-Received: from pli-ubuntu.sh.intel.com (pli-ubuntu.sh.intel.com [10.239.159.47])
-	by shvmail03.sh.intel.com (Postfix) with ESMTP id E43A71007C1D;
-	Mon, 10 Jun 2024 22:49:02 +0800 (CST)
-From: pan2.li@intel.com
-To: gcc-patches@gcc.gnu.org
-Cc: juzhe.zhong@rivai.ai,
-	kito.cheng@gmail.com,
-	richard.guenther@gmail.com,
-	Pan Li <pan2.li@intel.com>
-Subject: [PATCH v1] Widening-Mul: Fix one ICE of gcall insertion for PHI match
-Date: Mon, 10 Jun 2024 22:49:01 +0800
-Message-Id: <20240610144901.3723532-1-pan2.li@intel.com>
-X-Mailer: git-send-email 2.34.1
-MIME-Version: 1.0
-Content-Transfer-Encoding: 8bit
-X-Spam-Status: No, score=-11.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH,DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,GIT_PATCH_0,KAM_SHORT,SPF_HELO_NONE,SPF_NONE,TXREP,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6
-X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on server2.sourceware.org
-List-Id: <gcc-patches.gcc.gnu.org>
-
-From: Pan Li <pan2.li@intel.com>
-
-When enabled the PHI handing for COND_EXPR,  we need to insert the gcall
-to replace the PHI node.  Unfortunately,  I made a mistake that insert
-the gcall to before the last stmt of the bb.  See below gimple,  the PHI
-is located at no.1 but we insert the gcall (aka no.9) to the end of
-the bb.  Then the use of _9 in no.2 will have no def and will trigger
-ICE when verify_ssa.
-
-  1. # _9 = PHI <_3(4), 18446744073709551615(3)> // The PHI node to be deleted.
-  2. prephitmp_36 = (char *) _9;
-  3. buf.write_base = string_13(D);
-  4. buf.write_ptr = string_13(D);
-  5. buf.write_end = prephitmp_36;
-  6. buf.written = 0;
-  7. buf.mode = 3;
-  8. _7 = buf.write_end;
-  9. _9 = .SAT_ADD (string.0_2, maxlen_15(D));   // Insert gcall to last bb by mistake
-
-This patch would like to insert the gcall to before the start of the bb
-stmt.  To ensure the possible use of PHI_result will have a def exists.
-After this patch the above gimple will be:
-
-  0. _9 = .SAT_ADD (string.0_2, maxlen_15(D));   // Insert gcall to start bb by mistake
-  1. # _9 = PHI <_3(4), 18446744073709551615(3)> // The PHI node to be deleted.
-  2. prephitmp_36 = (char *) _9;
-  3. buf.write_base = string_13(D);
-  4. buf.write_ptr = string_13(D);
-  5. buf.write_end = prephitmp_36;
-  6. buf.written = 0;
-  7. buf.mode = 3;
-  8. _7 = buf.write_end;
-
-The below test suites are passed for this patch:
-* The rv64gcv fully regression test with newlib.
-* The rv64gcv build with glibc.
-* The x86 regression test with newlib.
-* The x86 bootstrap test with newlib.
-
-	PR target/115387
-
-gcc/ChangeLog:
-
-	* tree-ssa-math-opts.cc (math_opts_dom_walker::after_dom_children): Take
-	the gsi of start_bb instead of last_bb.
-
-gcc/testsuite/ChangeLog:
-
-	* gcc.target/riscv/pr115387-1.c: New test.
-	* gcc.target/riscv/pr115387-2.c: New test.
-
-Signed-off-by: Pan Li <pan2.li@intel.com>
----
- gcc/testsuite/gcc.target/riscv/pr115387-1.c | 35 +++++++++++++++++++++
- gcc/testsuite/gcc.target/riscv/pr115387-2.c | 18 +++++++++++
- gcc/tree-ssa-math-opts.cc                   |  2 +-
- 3 files changed, 54 insertions(+), 1 deletion(-)
- create mode 100644 gcc/testsuite/gcc.target/riscv/pr115387-1.c
- create mode 100644 gcc/testsuite/gcc.target/riscv/pr115387-2.c
-
-diff --git a/gcc/testsuite/gcc.target/riscv/pr115387-1.c b/gcc/testsuite/gcc.target/riscv/pr115387-1.c
-new file mode 100644
-index 00000000000..a1c926977c4
---- /dev/null
-+++ b/gcc/testsuite/gcc.target/riscv/pr115387-1.c
-@@ -0,0 +1,35 @@
-+/* Test there is no ICE when compile.  */
-+/* { dg-do compile } */
-+/* { dg-options "-march=rv64gcv -mabi=lp64d -O3" } */
-+
-+#define PRINTF_CHK 0x34
-+
-+typedef unsigned long uintptr_t;
-+
-+struct __printf_buffer {
-+  char *write_ptr;
-+  int status;
-+};
-+
-+extern void __printf_buffer_init_end (struct __printf_buffer *, char *, char *);
-+
-+void
-+test (char *string, unsigned long maxlen, unsigned mode_flags)
-+{
-+  struct __printf_buffer buf;
-+
-+  if ((mode_flags & PRINTF_CHK) != 0)
-+    {
-+      string[0] = '\0';
-+      uintptr_t end;
-+
-+      if (__builtin_add_overflow ((uintptr_t) string, maxlen, &end))
-+	end = -1;
-+
-+      __printf_buffer_init_end (&buf, string, (char *) end);
-+    }
-+  else
-+    __printf_buffer_init_end (&buf, string, (char *) ~(uintptr_t) 0);
-+
-+  *buf.write_ptr = '\0';
-+}
-diff --git a/gcc/testsuite/gcc.target/riscv/pr115387-2.c b/gcc/testsuite/gcc.target/riscv/pr115387-2.c
-new file mode 100644
-index 00000000000..7183bf18dfd
---- /dev/null
-+++ b/gcc/testsuite/gcc.target/riscv/pr115387-2.c
-@@ -0,0 +1,18 @@
-+/* Test there is no ICE when compile.  */
-+/* { dg-do compile } */
-+/* { dg-options "-march=rv64gcv -mabi=lp64d -O3" } */
-+
-+#include <stddef.h>
-+#include <stdint-gcc.h>
-+
-+char *
-+test (char *string, size_t maxlen)
-+{
-+  string[0] = '\0';
-+  uintptr_t end;
-+
-+  if (__builtin_add_overflow ((uintptr_t) string, maxlen, &end))
-+    end = -1;
-+
-+  return (char *) end;
-+}
-diff --git a/gcc/tree-ssa-math-opts.cc b/gcc/tree-ssa-math-opts.cc
-index 173b0366f5e..fbb8e0ea306 100644
---- a/gcc/tree-ssa-math-opts.cc
-+++ b/gcc/tree-ssa-math-opts.cc
-@@ -6102,7 +6102,7 @@ math_opts_dom_walker::after_dom_children (basic_block bb)
-   for (gphi_iterator psi = gsi_start_phis (bb); !gsi_end_p (psi);
-     gsi_next (&psi))
-     {
--      gimple_stmt_iterator gsi = gsi_last_bb (bb);
-+      gimple_stmt_iterator gsi = gsi_start_bb (bb);
-       match_unsigned_saturation_add (&gsi, psi.phi ());
-     }
- 
--- 
-2.34.1
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 81ca552..6c43a46 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 4	????
 
+	- 77_all_PR115387.patch
 	- 78_all_PR115395.patch
 
 3	10 June 2024
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-06-16 22:45 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-06-16 22:45 UTC (permalink / raw
  To: gentoo-commits
commit:     9b921e3a315f6c478a72c39a444ed694438fdcb2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 16 22:45:05 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun 16 22:45:05 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=9b921e3a
15.0.0: cut patchset 4
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 6c43a46..efe48af 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-4	????
+4	16 June 2024
 
 	- 77_all_PR115387.patch
 	- 78_all_PR115395.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-06-26 23:57 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-06-26 23:57 UTC (permalink / raw
  To: gentoo-commits
commit:     e35c53788a928179ef26b76833bcbe297f84fe6a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Jun 26 23:57:28 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 26 23:57:52 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=e35c5378
15.0.0: workaround recent x86 changes
Bug: https://gcc.gnu.org/PR115635
Bug: https://gcc.gnu.org/PR115661
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../gentoo/77_all_i386-fix-ix86_expand_move.patch  | 45 ++++++++++
 .../78_all_i386-fix-recent-alias-set-change.patch  | 95 ++++++++++++++++++++++
 2 files changed, 140 insertions(+)
diff --git a/15.0.0/gentoo/77_all_i386-fix-ix86_expand_move.patch b/15.0.0/gentoo/77_all_i386-fix-ix86_expand_move.patch
new file mode 100644
index 0000000..4b42ea9
--- /dev/null
+++ b/15.0.0/gentoo/77_all_i386-fix-ix86_expand_move.patch
@@ -0,0 +1,45 @@
+From ec0ead755e65ba51813aa8b66f4eb5574dd8437c Mon Sep 17 00:00:00 2001
+From: Sam James <sam@gentoo.org>
+Date: Wed, 26 Jun 2024 13:19:42 +0100
+Subject: [PATCH 1/2] i386: fix ix86_expand_move
+
+Before r15-1599-g63512c72df09b4, legitimize_pe_coff_symbol would return NULL_RTX
+for non-PECOFF targets, so the else branch would get taken.
+
+(This is a hack which doesn't work for PECOFF targets but fixes miscompilations
+on ELF.)
+
+Bug: https://gcc.gnu.org/PR115635
+Bug: https://gcc.gnu.org/PR115661
+---
+ gcc/config/i386/i386-expand.cc | 10 ----------
+ 1 file changed, 10 deletions(-)
+
+diff --git a/gcc/config/i386/i386-expand.cc b/gcc/config/i386/i386-expand.cc
+index 5dfa7d49f58c..5e0173bc7a84 100644
+--- a/gcc/config/i386/i386-expand.cc
++++ b/gcc/config/i386/i386-expand.cc
+@@ -412,20 +412,10 @@ ix86_expand_move (machine_mode mode, rtx operands[])
+ 	}
+       else
+ 	{
+-#if TARGET_PECOFF
+-	  tmp = legitimize_pe_coff_symbol (op1, addend != NULL_RTX);
+-	  if (tmp)
+-	    {
+-	      op1 = tmp;
+-	      if (!addend)
+-		break;
+-	    }
+-	  else
+ 	    {
+ 	      op1 = operands[1];
+ 	      break;
+ 	    }
+-#endif
+ 	}
+ 
+       if (addend)
+-- 
+2.45.2
+
diff --git a/15.0.0/gentoo/78_all_i386-fix-recent-alias-set-change.patch b/15.0.0/gentoo/78_all_i386-fix-recent-alias-set-change.patch
new file mode 100644
index 0000000..6776fdd
--- /dev/null
+++ b/15.0.0/gentoo/78_all_i386-fix-recent-alias-set-change.patch
@@ -0,0 +1,95 @@
+From 72a4d2d437782afa975f9b29c3ab4a1826ad0cd6 Mon Sep 17 00:00:00 2001
+From: Sam James <sam@gentoo.org>
+Date: Wed, 26 Jun 2024 12:54:55 +0100
+Subject: [PATCH 2/2] i386: fix recent alias set change
+
+Before r15-1599-g63512c72df09b4, we would create a new alias set, but now
+we use -1. Go back to using ix86_GOT_alias_set.
+
+(This is a hack which isn't the cleanest way of fixing it.)
+
+Bug: https://gcc.gnu.org/PR115635
+Bug: https://gcc.gnu.org/PR115661
+---
+ gcc/config/i386/i386-expand.cc |  2 +-
+ gcc/config/i386/i386-expand.h  |  1 +
+ gcc/config/i386/i386.cc        | 17 ++++++++++++++---
+ 3 files changed, 16 insertions(+), 4 deletions(-)
+
+diff --git a/gcc/config/i386/i386-expand.cc b/gcc/config/i386/i386-expand.cc
+index 5e0173bc7a84..3345f40ad85d 100644
+--- a/gcc/config/i386/i386-expand.cc
++++ b/gcc/config/i386/i386-expand.cc
+@@ -408,7 +408,7 @@ ix86_expand_move (machine_mode mode, rtx operands[])
+ 				 : UNSPEC_GOT));
+ 	  op1 = gen_rtx_CONST (Pmode, op1);
+ 	  op1 = gen_const_mem (Pmode, op1);
+-	  set_mem_alias_set (op1, GOT_ALIAS_SET);
++	  set_mem_alias_set (op1, ix86_GOT_alias_set ());
+ 	}
+       else
+ 	{
+diff --git a/gcc/config/i386/i386-expand.h b/gcc/config/i386/i386-expand.h
+index 5e02df1706df..56bee29253ba 100644
+--- a/gcc/config/i386/i386-expand.h
++++ b/gcc/config/i386/i386-expand.h
+@@ -34,6 +34,7 @@ struct expand_vec_perm_d
+ };
+ 
+ rtx legitimize_tls_address (rtx x, enum tls_model model, bool for_mov);
++alias_set_type ix86_GOT_alias_set (void);
+ rtx legitimize_pic_address (rtx orig, rtx reg);
+ 
+ bool insn_defines_reg (unsigned int regno1, unsigned int regno2,
+diff --git a/gcc/config/i386/i386.cc b/gcc/config/i386/i386.cc
+index 1f71ed04be67..62fca080f2f5 100644
+--- a/gcc/config/i386/i386.cc
++++ b/gcc/config/i386/i386.cc
+@@ -11823,6 +11823,17 @@ constant_address_p (rtx x)
+ }
+ \f
+ 
++/* Return a unique alias set for the GOT.  */
++
++alias_set_type
++ix86_GOT_alias_set (void)
++{
++  static alias_set_type set = -1;
++  if (set == -1)
++    set = new_alias_set ();
++  return set;
++}
++
+ /* Return a legitimate reference for ORIG (an address) using the
+    register REG.  If REG is 0, a new pseudo is generated.
+ 
+@@ -11925,7 +11936,7 @@ legitimize_pic_address (rtx orig, rtx reg)
+ 				    UNSPEC_GOTPCREL);
+ 	  new_rtx = gen_rtx_CONST (Pmode, new_rtx);
+ 	  new_rtx = gen_const_mem (Pmode, new_rtx);
+-	  set_mem_alias_set (new_rtx, GOT_ALIAS_SET);
++	  set_mem_alias_set (new_rtx, ix86_GOT_alias_set ());
+ 	}
+       else
+ 	{
+@@ -11947,7 +11958,7 @@ legitimize_pic_address (rtx orig, rtx reg)
+ 	    new_rtx = gen_rtx_PLUS (Pmode, pic_offset_table_rtx, new_rtx);
+ 
+ 	  new_rtx = gen_const_mem (Pmode, new_rtx);
+-	  set_mem_alias_set (new_rtx, GOT_ALIAS_SET);
++	  set_mem_alias_set (new_rtx, ix86_GOT_alias_set ());
+ 	}
+ 
+       new_rtx = copy_to_suggested_reg (new_rtx, reg, Pmode);
+@@ -12324,7 +12335,7 @@ legitimize_tls_address (rtx x, enum tls_model model, bool for_mov)
+       if (pic)
+ 	off = gen_rtx_PLUS (tp_mode, pic, off);
+       off = gen_const_mem (tp_mode, off);
+-      set_mem_alias_set (off, GOT_ALIAS_SET);
++      set_mem_alias_set (off, ix86_GOT_alias_set ());
+ 
+       if (TARGET_64BIT || TARGET_ANY_GNU_TLS)
+ 	{
+-- 
+2.45.2
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-06-27  0:02 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-06-27  0:02 UTC (permalink / raw
  To: gentoo-commits
commit:     7760ff0bf2fd5fa05385fc11158cb7efd7a05cc5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jun 27 00:02:16 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun 27 00:02:16 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=7760ff0b
15.0.0: add revert annotation
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/77_all_i386-fix-ix86_expand_move.patch        | 2 ++
 15.0.0/gentoo/78_all_i386-fix-recent-alias-set-change.patch | 2 ++
 2 files changed, 4 insertions(+)
diff --git a/15.0.0/gentoo/77_all_i386-fix-ix86_expand_move.patch b/15.0.0/gentoo/77_all_i386-fix-ix86_expand_move.patch
index 4b42ea9..2b5b8d4 100644
--- a/15.0.0/gentoo/77_all_i386-fix-ix86_expand_move.patch
+++ b/15.0.0/gentoo/77_all_i386-fix-ix86_expand_move.patch
@@ -9,6 +9,8 @@ for non-PECOFF targets, so the else branch would get taken.
 (This is a hack which doesn't work for PECOFF targets but fixes miscompilations
 on ELF.)
 
+This partially reverts commit r15-1599-g63512c72df09b4.
+
 Bug: https://gcc.gnu.org/PR115635
 Bug: https://gcc.gnu.org/PR115661
 ---
diff --git a/15.0.0/gentoo/78_all_i386-fix-recent-alias-set-change.patch b/15.0.0/gentoo/78_all_i386-fix-recent-alias-set-change.patch
index 6776fdd..eb8f5bd 100644
--- a/15.0.0/gentoo/78_all_i386-fix-recent-alias-set-change.patch
+++ b/15.0.0/gentoo/78_all_i386-fix-recent-alias-set-change.patch
@@ -8,6 +8,8 @@ we use -1. Go back to using ix86_GOT_alias_set.
 
 (This is a hack which isn't the cleanest way of fixing it.)
 
+This partially reverts commit r15-1599-g63512c72df09b4.
+
 Bug: https://gcc.gnu.org/PR115635
 Bug: https://gcc.gnu.org/PR115661
 ---
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-06-28 12:49 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-06-28 12:49 UTC (permalink / raw
  To: gentoo-commits
commit:     b97a75814a0b8969a5669c761dde86dc0d9ee2a1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 28 12:49:23 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun 28 12:49:23 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b97a7581
15.0.0: drop x86 backend fixes
Now fixed upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../gentoo/77_all_i386-fix-ix86_expand_move.patch  | 47 -----------
 .../78_all_i386-fix-recent-alias-set-change.patch  | 97 ----------------------
 2 files changed, 144 deletions(-)
diff --git a/15.0.0/gentoo/77_all_i386-fix-ix86_expand_move.patch b/15.0.0/gentoo/77_all_i386-fix-ix86_expand_move.patch
deleted file mode 100644
index 2b5b8d4..0000000
--- a/15.0.0/gentoo/77_all_i386-fix-ix86_expand_move.patch
+++ /dev/null
@@ -1,47 +0,0 @@
-From ec0ead755e65ba51813aa8b66f4eb5574dd8437c Mon Sep 17 00:00:00 2001
-From: Sam James <sam@gentoo.org>
-Date: Wed, 26 Jun 2024 13:19:42 +0100
-Subject: [PATCH 1/2] i386: fix ix86_expand_move
-
-Before r15-1599-g63512c72df09b4, legitimize_pe_coff_symbol would return NULL_RTX
-for non-PECOFF targets, so the else branch would get taken.
-
-(This is a hack which doesn't work for PECOFF targets but fixes miscompilations
-on ELF.)
-
-This partially reverts commit r15-1599-g63512c72df09b4.
-
-Bug: https://gcc.gnu.org/PR115635
-Bug: https://gcc.gnu.org/PR115661
----
- gcc/config/i386/i386-expand.cc | 10 ----------
- 1 file changed, 10 deletions(-)
-
-diff --git a/gcc/config/i386/i386-expand.cc b/gcc/config/i386/i386-expand.cc
-index 5dfa7d49f58c..5e0173bc7a84 100644
---- a/gcc/config/i386/i386-expand.cc
-+++ b/gcc/config/i386/i386-expand.cc
-@@ -412,20 +412,10 @@ ix86_expand_move (machine_mode mode, rtx operands[])
- 	}
-       else
- 	{
--#if TARGET_PECOFF
--	  tmp = legitimize_pe_coff_symbol (op1, addend != NULL_RTX);
--	  if (tmp)
--	    {
--	      op1 = tmp;
--	      if (!addend)
--		break;
--	    }
--	  else
- 	    {
- 	      op1 = operands[1];
- 	      break;
- 	    }
--#endif
- 	}
- 
-       if (addend)
--- 
-2.45.2
-
diff --git a/15.0.0/gentoo/78_all_i386-fix-recent-alias-set-change.patch b/15.0.0/gentoo/78_all_i386-fix-recent-alias-set-change.patch
deleted file mode 100644
index eb8f5bd..0000000
--- a/15.0.0/gentoo/78_all_i386-fix-recent-alias-set-change.patch
+++ /dev/null
@@ -1,97 +0,0 @@
-From 72a4d2d437782afa975f9b29c3ab4a1826ad0cd6 Mon Sep 17 00:00:00 2001
-From: Sam James <sam@gentoo.org>
-Date: Wed, 26 Jun 2024 12:54:55 +0100
-Subject: [PATCH 2/2] i386: fix recent alias set change
-
-Before r15-1599-g63512c72df09b4, we would create a new alias set, but now
-we use -1. Go back to using ix86_GOT_alias_set.
-
-(This is a hack which isn't the cleanest way of fixing it.)
-
-This partially reverts commit r15-1599-g63512c72df09b4.
-
-Bug: https://gcc.gnu.org/PR115635
-Bug: https://gcc.gnu.org/PR115661
----
- gcc/config/i386/i386-expand.cc |  2 +-
- gcc/config/i386/i386-expand.h  |  1 +
- gcc/config/i386/i386.cc        | 17 ++++++++++++++---
- 3 files changed, 16 insertions(+), 4 deletions(-)
-
-diff --git a/gcc/config/i386/i386-expand.cc b/gcc/config/i386/i386-expand.cc
-index 5e0173bc7a84..3345f40ad85d 100644
---- a/gcc/config/i386/i386-expand.cc
-+++ b/gcc/config/i386/i386-expand.cc
-@@ -408,7 +408,7 @@ ix86_expand_move (machine_mode mode, rtx operands[])
- 				 : UNSPEC_GOT));
- 	  op1 = gen_rtx_CONST (Pmode, op1);
- 	  op1 = gen_const_mem (Pmode, op1);
--	  set_mem_alias_set (op1, GOT_ALIAS_SET);
-+	  set_mem_alias_set (op1, ix86_GOT_alias_set ());
- 	}
-       else
- 	{
-diff --git a/gcc/config/i386/i386-expand.h b/gcc/config/i386/i386-expand.h
-index 5e02df1706df..56bee29253ba 100644
---- a/gcc/config/i386/i386-expand.h
-+++ b/gcc/config/i386/i386-expand.h
-@@ -34,6 +34,7 @@ struct expand_vec_perm_d
- };
- 
- rtx legitimize_tls_address (rtx x, enum tls_model model, bool for_mov);
-+alias_set_type ix86_GOT_alias_set (void);
- rtx legitimize_pic_address (rtx orig, rtx reg);
- 
- bool insn_defines_reg (unsigned int regno1, unsigned int regno2,
-diff --git a/gcc/config/i386/i386.cc b/gcc/config/i386/i386.cc
-index 1f71ed04be67..62fca080f2f5 100644
---- a/gcc/config/i386/i386.cc
-+++ b/gcc/config/i386/i386.cc
-@@ -11823,6 +11823,17 @@ constant_address_p (rtx x)
- }
- \f
- 
-+/* Return a unique alias set for the GOT.  */
-+
-+alias_set_type
-+ix86_GOT_alias_set (void)
-+{
-+  static alias_set_type set = -1;
-+  if (set == -1)
-+    set = new_alias_set ();
-+  return set;
-+}
-+
- /* Return a legitimate reference for ORIG (an address) using the
-    register REG.  If REG is 0, a new pseudo is generated.
- 
-@@ -11925,7 +11936,7 @@ legitimize_pic_address (rtx orig, rtx reg)
- 				    UNSPEC_GOTPCREL);
- 	  new_rtx = gen_rtx_CONST (Pmode, new_rtx);
- 	  new_rtx = gen_const_mem (Pmode, new_rtx);
--	  set_mem_alias_set (new_rtx, GOT_ALIAS_SET);
-+	  set_mem_alias_set (new_rtx, ix86_GOT_alias_set ());
- 	}
-       else
- 	{
-@@ -11947,7 +11958,7 @@ legitimize_pic_address (rtx orig, rtx reg)
- 	    new_rtx = gen_rtx_PLUS (Pmode, pic_offset_table_rtx, new_rtx);
- 
- 	  new_rtx = gen_const_mem (Pmode, new_rtx);
--	  set_mem_alias_set (new_rtx, GOT_ALIAS_SET);
-+	  set_mem_alias_set (new_rtx, ix86_GOT_alias_set ());
- 	}
- 
-       new_rtx = copy_to_suggested_reg (new_rtx, reg, Pmode);
-@@ -12324,7 +12335,7 @@ legitimize_tls_address (rtx x, enum tls_model model, bool for_mov)
-       if (pic)
- 	off = gen_rtx_PLUS (tp_mode, pic, off);
-       off = gen_const_mem (tp_mode, off);
--      set_mem_alias_set (off, GOT_ALIAS_SET);
-+      set_mem_alias_set (off, ix86_GOT_alias_set ());
- 
-       if (TARGET_64BIT || TARGET_ANY_GNU_TLS)
- 	{
--- 
-2.45.2
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-07-14 23:36 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-07-14 23:36 UTC (permalink / raw
  To: gentoo-commits
commit:     f3f27691478a0b256a3b52348bae96f5a6b5f089
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 14 23:35:47 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 14 23:35:47 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=f3f27691
15.0.0: don't enable -fext-dce with -O2
Bug: https://gcc.gnu.org/PR115876
Bug: https://gcc.gnu.org/PR115877
Bug: https://gcc.gnu.org/PR115912
Bug: https://gcc.gnu.org/PR115916
Bug: https://gcc.gnu.org/PR115927
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...gcc_don-t-enable-fext-dce-with-O2-for-now.patch | 34 ++++++++++++++++++++++
 15.0.0/gentoo/README.history                       |  4 +++
 2 files changed, 38 insertions(+)
diff --git a/15.0.0/gentoo/78_all_gcc_don-t-enable-fext-dce-with-O2-for-now.patch b/15.0.0/gentoo/78_all_gcc_don-t-enable-fext-dce-with-O2-for-now.patch
new file mode 100644
index 0000000..82c5535
--- /dev/null
+++ b/15.0.0/gentoo/78_all_gcc_don-t-enable-fext-dce-with-O2-for-now.patch
@@ -0,0 +1,34 @@
+From 86de2fd7550f75a318aa9819b115487cd850b4fc Mon Sep 17 00:00:00 2001
+From: Sam James <sam@gentoo.org>
+Date: Mon, 15 Jul 2024 00:32:18 +0100
+Subject: [PATCH] gcc: don't enable -fext-dce with -O2 for now
+
+There's too many bugs involving it for now.
+
+    gcc/
+            * opts.cc (default_options_table): Don't enable ext-dce at -O2
+
+Bug: https://gcc.gnu.org/PR115876
+Bug: https://gcc.gnu.org/PR115877
+Bug: https://gcc.gnu.org/PR115912
+Bug: https://gcc.gnu.org/PR115916
+Bug: https://gcc.gnu.org/PR115927
+---
+ gcc/opts.cc | 1 -
+ 1 file changed, 1 deletion(-)
+
+diff --git a/gcc/opts.cc b/gcc/opts.cc
+index be90a632338f..e1a1bdf15822 100644
+--- a/gcc/opts.cc
++++ b/gcc/opts.cc
+@@ -634,7 +634,6 @@ static const struct default_options default_options_table[] =
+     { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
+     { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
+     { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
+-    { OPT_LEVELS_2_PLUS, OPT_fext_dce, NULL, 1 },
+     { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
+     { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
+     { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
+-- 
+2.45.2
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index efe48af..eddda8f 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+5	15 July 2024
+
+	+ 78_all_gcc_don-t-enable-fext-dce-with-O2-for-now.patch
+
 4	16 June 2024
 
 	- 77_all_PR115387.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-07-18  0:45 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-07-18  0:45 UTC (permalink / raw
  To: gentoo-commits
commit:     3caa1b3eb3879d24c604ffa282b1c4b2c17fc391
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 18 00:44:35 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jul 18 00:44:35 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=3caa1b3e
15.0.0: update power7 .feature patch
Switch to Peter's version. Can update older branches once it's merged.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../76_all_ppc_PR97367-power7-cell-altivec.patch   | 102 ++++++++++++++++++++-
 1 file changed, 99 insertions(+), 3 deletions(-)
diff --git a/15.0.0/gentoo/76_all_ppc_PR97367-power7-cell-altivec.patch b/15.0.0/gentoo/76_all_ppc_PR97367-power7-cell-altivec.patch
index 154dd0f..d4ca6c2 100644
--- a/15.0.0/gentoo/76_all_ppc_PR97367-power7-cell-altivec.patch
+++ b/15.0.0/gentoo/76_all_ppc_PR97367-power7-cell-altivec.patch
@@ -1,13 +1,109 @@
 https://gcc.gnu.org/PR97367
-https://inbox.sourceware.org/gcc-patches/20240308.123342.1112119677226246836.rene@exactcode.de/
+https://inbox.sourceware.org/gcc-patches/5f2b5d5e-a682-4084-b70e-89929f4cc6dc@bergner.org/T/#u
+
+From git@z Thu Jan  1 00:00:00 1970
+Subject: [PATCH v2] rs6000: Fix .machine cpu selection w/ altivec [PR97367]
+From: Peter Bergner <pshop@bergner.org>
+Date: Fri, 12 Jul 2024 16:48:29 -0500
+Message-Id: <5f2b5d5e-a682-4084-b70e-89929f4cc6dc@bergner.org>
+MIME-Version: 1.0
+Content-Type: text/plain; charset="utf-8"
+Content-Transfer-Encoding: 8bit
+
+René's patch seems to have stalled, so here is an updated version of the
+patch with the requested changes to his patch.
+
+I'll note I have added an additional code change, which is to also emit a
+".machine altivec" if Altivec is enabled.  The problem this fixes is for
+cpus like the G5, which is basically a power4 plus an Altivec unit, its
+".machine power4" doesn't enable the assembler to recognize Altivec insns.
+That isn't a problem if you use gcc -mcpu=G5 to assemble the assembler file,
+since gcc passes -maltivec to the assembler.  However, if you try to assemble
+the assembler file with as by hand, you'll get "unrecognized opcode" errors.
+I did not do the same for VSX, since all ".machine <cpu>" for cpus that
+support VSX already enable VSX insn recognition, so it's not needed.
+
+
+rs6000: Fix .machine cpu selection w/ altivec [PR97367]
+
+There are various non-IBM CPUs with altivec, so we cannot use that
+flag to determine which .machine cpu to use, so ignore it.
+Emit an additional ".machine altivec" if Altivec is enabled so
+that the assembler doesn't require an explicit -maltivec option
+to assemble any Altivec instructions for those targets where
+the ".machine cpu" is insufficient to enable Altivec.  For example,
+-mcpu=G5 emits a ".machine power4".
+
+This passed bootstrap and regtesting on powrpc64-linux (running the testsuite
+in both 32-bit and 64-bit modes) with no regressions.
+
+Ok for trunk and the release branches after some trunk burn-in time?
+
+Peter
+
+
+2024-07-12  René Rebe  <rene@exactcode.de>
+	    Peter Bergner  <bergner@linux.ibm.com>
+
+gcc/
+	PR target/97367
+	* config/rs6000/rs6000.c (rs6000_machine_from_flags): Do not consider
+	OPTION_MASK_ALTIVEC.
+	(emit_asm_machine): For Altivec compiles, emit a ".machine altivec".
+
+gcc/testsuite/
+	PR target/97367
+	* gcc.target/powerpc/pr97367.c: New test.
+
+Signed-of-by: René Rebe <rene@exactcode.de>
+---
+ gcc/config/rs6000/rs6000.cc                |  5 ++++-
+ gcc/testsuite/gcc.target/powerpc/pr97367.c | 13 +++++++++++++
+ 2 files changed, 17 insertions(+), 1 deletion(-)
+ create mode 100644 gcc/testsuite/gcc.target/powerpc/pr97367.c
+
+diff --git a/gcc/config/rs6000/rs6000.cc b/gcc/config/rs6000/rs6000.cc
+index 2cbea6ea2d7..2cb8f35739b 100644
 --- a/gcc/config/rs6000/rs6000.cc
 +++ b/gcc/config/rs6000/rs6000.cc
-@@ -5869,7 +5869,7 @@ rs6000_machine_from_flags (void)
+@@ -5888,7 +5888,8 @@ rs6000_machine_from_flags (void)
    HOST_WIDE_INT flags = rs6000_isa_flags;
  
    /* Disable the flags that should never influence the .machine selection.  */
 -  flags &= ~(OPTION_MASK_PPC_GFXOPT | OPTION_MASK_PPC_GPOPT | OPTION_MASK_ISEL);
-+  flags &= ~(OPTION_MASK_PPC_GFXOPT | OPTION_MASK_PPC_GPOPT | OPTION_MASK_ALTIVEC | OPTION_MASK_ISEL);
++  flags &= ~(OPTION_MASK_PPC_GFXOPT | OPTION_MASK_PPC_GPOPT | OPTION_MASK_ISEL
++	     | OPTION_MASK_ALTIVEC);
  
    if ((flags & (ISA_3_1_MASKS_SERVER & ~ISA_3_0_MASKS_SERVER)) != 0)
      return "power10";
+@@ -5913,6 +5914,8 @@ void
+ emit_asm_machine (void)
+ {
+   fprintf (asm_out_file, "\t.machine %s\n", rs6000_machine);
++  if (TARGET_ALTIVEC)
++    fprintf (asm_out_file, "\t.machine altivec\n");
+ }
+ #endif
+ 
+diff --git a/gcc/testsuite/gcc.target/powerpc/pr97367.c b/gcc/testsuite/gcc.target/powerpc/pr97367.c
+new file mode 100644
+index 00000000000..f9118dbcdec
+--- /dev/null
++++ b/gcc/testsuite/gcc.target/powerpc/pr97367.c
+@@ -0,0 +1,13 @@
++/* PR target/97367 */
++/* { dg-options "-mdejagnu-cpu=G5" } */
++
++/* Verify we emit a ".machine power4" and ".machine altivec" rather
++   than a ".machine power7".  */
++
++int dummy (void)
++{
++  return 0;
++}
++
++/* { dg-final { scan-assembler {\.\mmachine power4\M} } } */
++/* { dg-final { scan-assembler {\.\mmachine altivec\M} } } */
+-- 
+2.45.2
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-07-19 11:14 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-07-19 11:14 UTC (permalink / raw
  To: gentoo-commits
commit:     3147d1f67ddd03e579d1ff19aea8b9cfeb490564
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Jul 19 11:14:06 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul 19 11:14:06 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=3147d1f6
15.0.0: drop upstream power7 patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../76_all_ppc_PR97367-power7-cell-altivec.patch   | 109 ---------------------
 15.0.0/gentoo/README.history                       |   4 +
 2 files changed, 4 insertions(+), 109 deletions(-)
diff --git a/15.0.0/gentoo/76_all_ppc_PR97367-power7-cell-altivec.patch b/15.0.0/gentoo/76_all_ppc_PR97367-power7-cell-altivec.patch
deleted file mode 100644
index d4ca6c2..0000000
--- a/15.0.0/gentoo/76_all_ppc_PR97367-power7-cell-altivec.patch
+++ /dev/null
@@ -1,109 +0,0 @@
-https://gcc.gnu.org/PR97367
-https://inbox.sourceware.org/gcc-patches/5f2b5d5e-a682-4084-b70e-89929f4cc6dc@bergner.org/T/#u
-
-From git@z Thu Jan  1 00:00:00 1970
-Subject: [PATCH v2] rs6000: Fix .machine cpu selection w/ altivec [PR97367]
-From: Peter Bergner <pshop@bergner.org>
-Date: Fri, 12 Jul 2024 16:48:29 -0500
-Message-Id: <5f2b5d5e-a682-4084-b70e-89929f4cc6dc@bergner.org>
-MIME-Version: 1.0
-Content-Type: text/plain; charset="utf-8"
-Content-Transfer-Encoding: 8bit
-
-René's patch seems to have stalled, so here is an updated version of the
-patch with the requested changes to his patch.
-
-I'll note I have added an additional code change, which is to also emit a
-".machine altivec" if Altivec is enabled.  The problem this fixes is for
-cpus like the G5, which is basically a power4 plus an Altivec unit, its
-".machine power4" doesn't enable the assembler to recognize Altivec insns.
-That isn't a problem if you use gcc -mcpu=G5 to assemble the assembler file,
-since gcc passes -maltivec to the assembler.  However, if you try to assemble
-the assembler file with as by hand, you'll get "unrecognized opcode" errors.
-I did not do the same for VSX, since all ".machine <cpu>" for cpus that
-support VSX already enable VSX insn recognition, so it's not needed.
-
-
-rs6000: Fix .machine cpu selection w/ altivec [PR97367]
-
-There are various non-IBM CPUs with altivec, so we cannot use that
-flag to determine which .machine cpu to use, so ignore it.
-Emit an additional ".machine altivec" if Altivec is enabled so
-that the assembler doesn't require an explicit -maltivec option
-to assemble any Altivec instructions for those targets where
-the ".machine cpu" is insufficient to enable Altivec.  For example,
--mcpu=G5 emits a ".machine power4".
-
-This passed bootstrap and regtesting on powrpc64-linux (running the testsuite
-in both 32-bit and 64-bit modes) with no regressions.
-
-Ok for trunk and the release branches after some trunk burn-in time?
-
-Peter
-
-
-2024-07-12  René Rebe  <rene@exactcode.de>
-	    Peter Bergner  <bergner@linux.ibm.com>
-
-gcc/
-	PR target/97367
-	* config/rs6000/rs6000.c (rs6000_machine_from_flags): Do not consider
-	OPTION_MASK_ALTIVEC.
-	(emit_asm_machine): For Altivec compiles, emit a ".machine altivec".
-
-gcc/testsuite/
-	PR target/97367
-	* gcc.target/powerpc/pr97367.c: New test.
-
-Signed-of-by: René Rebe <rene@exactcode.de>
----
- gcc/config/rs6000/rs6000.cc                |  5 ++++-
- gcc/testsuite/gcc.target/powerpc/pr97367.c | 13 +++++++++++++
- 2 files changed, 17 insertions(+), 1 deletion(-)
- create mode 100644 gcc/testsuite/gcc.target/powerpc/pr97367.c
-
-diff --git a/gcc/config/rs6000/rs6000.cc b/gcc/config/rs6000/rs6000.cc
-index 2cbea6ea2d7..2cb8f35739b 100644
---- a/gcc/config/rs6000/rs6000.cc
-+++ b/gcc/config/rs6000/rs6000.cc
-@@ -5888,7 +5888,8 @@ rs6000_machine_from_flags (void)
-   HOST_WIDE_INT flags = rs6000_isa_flags;
- 
-   /* Disable the flags that should never influence the .machine selection.  */
--  flags &= ~(OPTION_MASK_PPC_GFXOPT | OPTION_MASK_PPC_GPOPT | OPTION_MASK_ISEL);
-+  flags &= ~(OPTION_MASK_PPC_GFXOPT | OPTION_MASK_PPC_GPOPT | OPTION_MASK_ISEL
-+	     | OPTION_MASK_ALTIVEC);
- 
-   if ((flags & (ISA_3_1_MASKS_SERVER & ~ISA_3_0_MASKS_SERVER)) != 0)
-     return "power10";
-@@ -5913,6 +5914,8 @@ void
- emit_asm_machine (void)
- {
-   fprintf (asm_out_file, "\t.machine %s\n", rs6000_machine);
-+  if (TARGET_ALTIVEC)
-+    fprintf (asm_out_file, "\t.machine altivec\n");
- }
- #endif
- 
-diff --git a/gcc/testsuite/gcc.target/powerpc/pr97367.c b/gcc/testsuite/gcc.target/powerpc/pr97367.c
-new file mode 100644
-index 00000000000..f9118dbcdec
---- /dev/null
-+++ b/gcc/testsuite/gcc.target/powerpc/pr97367.c
-@@ -0,0 +1,13 @@
-+/* PR target/97367 */
-+/* { dg-options "-mdejagnu-cpu=G5" } */
-+
-+/* Verify we emit a ".machine power4" and ".machine altivec" rather
-+   than a ".machine power7".  */
-+
-+int dummy (void)
-+{
-+  return 0;
-+}
-+
-+/* { dg-final { scan-assembler {\.\mmachine power4\M} } } */
-+/* { dg-final { scan-assembler {\.\mmachine altivec\M} } } */
--- 
-2.45.2
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index eddda8f..e7d8bf0 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+6	?? ???? ????
+
+	- 76_all_ppc_PR97367-power7-cell-altivec.patch
+
 5	15 July 2024
 
 	+ 78_all_gcc_don-t-enable-fext-dce-with-O2-for-now.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-07-22  1:11 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-07-22  1:11 UTC (permalink / raw
  To: gentoo-commits
commit:     7203178939395f9d01a60a68073ec175ed0236c8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 22 01:11:43 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jul 22 01:11:43 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=72031789
15.0.0: cut patchset 6
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index e7d8bf0..81978cb 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-6	?? ???? ????
+6	22 July 2024
 
 	- 76_all_ppc_PR97367-power7-cell-altivec.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-07-28 23:34 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-07-28 23:34 UTC (permalink / raw
  To: gentoo-commits
commit:     4145ebad1e8382c5ec5ca26dadf21437aa37d172
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 28 23:34:10 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 28 23:34:10 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=4145ebad
15.0.0: add 79_all_PR116120-revert-match-pattern.patch
Bug: https://gcc.gnu.org/PR116120
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../79_all_PR116120-revert-match-pattern.patch     | 199 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   4 +
 2 files changed, 203 insertions(+)
diff --git a/15.0.0/gentoo/79_all_PR116120-revert-match-pattern.patch b/15.0.0/gentoo/79_all_PR116120-revert-match-pattern.patch
new file mode 100644
index 0000000..6d5b542
--- /dev/null
+++ b/15.0.0/gentoo/79_all_PR116120-revert-match-pattern.patch
@@ -0,0 +1,199 @@
+From fd07aecb306c682e1d7255fc01c6c02f3ca4f6f8 Mon Sep 17 00:00:00 2001
+Message-ID: <fd07aecb306c682e1d7255fc01c6c02f3ca4f6f8.1722209590.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Mon, 29 Jul 2024 00:32:52 +0100
+Subject: [PATCH] Revert "MATCH: Simplify (a ? x : y) eq/ne (b ? x : y)
+ [PR111150]"
+
+This reverts commit 44fcc1ca11e7ea35dc9fb25a5317346bc1eaf7b2.
+
+Avoid a reported & debugged miscompilation until it gets fixed.
+
+Bug: https://gcc.gnu.org/PR116120
+---
+ gcc/match.pd                               | 15 -----
+ gcc/testsuite/g++.dg/tree-ssa/pr111150.C   | 34 ----------
+ gcc/testsuite/gcc.dg/tree-ssa/pr111150-1.c | 72 ----------------------
+ gcc/testsuite/gcc.dg/tree-ssa/pr111150.c   | 22 -------
+ 4 files changed, 143 deletions(-)
+ delete mode 100644 gcc/testsuite/g++.dg/tree-ssa/pr111150.C
+ delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/pr111150-1.c
+ delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/pr111150.c
+
+diff --git a/gcc/match.pd b/gcc/match.pd
+index 1c8601229e3d..b8d0ebee08db 100644
+--- a/gcc/match.pd
++++ b/gcc/match.pd
+@@ -5632,21 +5632,6 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
+   (vec_cond (bit_and (bit_not @0) @1) @2 @3)))
+ #endif
+ 
+-/* (a ? x : y) != (b ? x : y) --> (a^b) ? TRUE  : FALSE */
+-/* (a ? x : y) == (b ? x : y) --> (a^b) ? FALSE : TRUE  */
+-/* (a ? x : y) != (b ? y : x) --> (a^b) ? FALSE : TRUE  */
+-/* (a ? x : y) == (b ? y : x) --> (a^b) ? TRUE  : FALSE */
+-(for cnd (cond vec_cond)
+- (for eqne (eq ne)
+-  (simplify
+-   (eqne:c (cnd @0 @1 @2) (cnd @3 @1 @2))
+-    (cnd (bit_xor @0 @3) { constant_boolean_node (eqne == NE_EXPR, type); }
+-     { constant_boolean_node (eqne != NE_EXPR, type); }))
+-  (simplify
+-   (eqne:c (cnd @0 @1 @2) (cnd @3 @2 @1))
+-    (cnd (bit_xor @0 @3) { constant_boolean_node (eqne != NE_EXPR, type); }
+-     { constant_boolean_node (eqne == NE_EXPR, type); }))))
+-
+ /* Canonicalize mask ? { 0, ... } : { -1, ...} to ~mask if the mask
+    types are compatible.  */
+ (simplify
+diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr111150.C b/gcc/testsuite/g++.dg/tree-ssa/pr111150.C
+deleted file mode 100644
+index ac5d3ef15d83..000000000000
+--- a/gcc/testsuite/g++.dg/tree-ssa/pr111150.C
++++ /dev/null
+@@ -1,34 +0,0 @@
+-/* PR tree-optimization/111150 */
+-/* { dg-do compile } */
+-/* { dg-options "-O1 -fdump-tree-forwprop1 -Wno-psabi" } */
+-
+-typedef int v4si __attribute((__vector_size__(4 * sizeof(int))));
+-
+-/* Before the patch, VEC_COND_EXPR was generated for each statement in the
+-   function. This resulted in 3 VEC_COND_EXPR. */
+-v4si f1_(v4si a, v4si b, v4si c, v4si d, v4si e, v4si f) {
+-  v4si X = a == b ? e : f;
+-  v4si Y = c == d ? e : f;
+-  return (X != Y);
+-}
+-
+-v4si f2_(v4si a, v4si b, v4si c, v4si d, v4si e, v4si f) {
+-  v4si X = a == b ? e : f;
+-  v4si Y = c == d ? e : f;
+-  return (X == Y);
+-}
+-
+-v4si f3_(v4si a, v4si b, v4si c, v4si d, v4si e, v4si f) {
+-  v4si X = a == b ? e : f;
+-  v4si Y = c == d ? f : e;
+-  return (X != Y);
+-}
+-
+-v4si f4_(v4si a, v4si b, v4si c, v4si d, v4si e, v4si f) {
+-  v4si X = a == b ? e : f;
+-  v4si Y = c == d ? f : e;
+-  return (X == Y);
+-}
+-
+-/* For each testcase, should produce only one VEC_COND_EXPR for X^Y. */
+-/* { dg-final { scan-tree-dump-times " VEC_COND_EXPR " 4 "forwprop1" } } */
+diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr111150-1.c b/gcc/testsuite/gcc.dg/tree-ssa/pr111150-1.c
+deleted file mode 100644
+index 6f4b21ac6bcb..000000000000
+--- a/gcc/testsuite/gcc.dg/tree-ssa/pr111150-1.c
++++ /dev/null
+@@ -1,72 +0,0 @@
+-/* PR tree-optimization/111150 */
+-/* { dg-do compile } */
+-/* { dg-options "-O1 -fgimple -fdump-tree-forwprop1-raw" } */
+-
+-/* Checks if pattern (X ? e : f) == (Y ? e : f) gets optimized. */
+-__GIMPLE()
+-_Bool f1_(int a, int b, int c, int d, int e, int f) {
+-  _Bool X;
+-  _Bool Y;
+-  _Bool t;
+-  int t1;
+-  int t2;
+-  X = a == b;
+-  Y = c == d;
+-  /* Before the patch cond_expr was generated for these 2 statements. */
+-  t1 = X ? e : f;
+-  t2 = Y ? e : f;
+-  t = t1 == t2;
+-  return t;
+-}
+-
+-/* Checks if pattern (X ? e : f) != (Y ? e : f) gets optimized. */
+-__GIMPLE()
+-_Bool f2_(int a, int b, int c, int d, int e, int f) {
+-  _Bool X;
+-  _Bool Y;
+-  _Bool t;
+-  int t1;
+-  int t2;
+-  X = a == b;
+-  Y = c == d;
+-  t1 = X ? e : f;
+-  t2 = Y ? e : f;
+-  t = t1 != t2;
+-  return t;
+-}
+-
+-/* Checks if pattern (X ? e : f) == (Y ? f : e) gets optimized. */
+-__GIMPLE()
+-_Bool f3_(int a, int b, int c, int d, int e, int f) {
+-  _Bool X;
+-  _Bool Y;
+-  _Bool t;
+-  int t1;
+-  int t2;
+-  X = a == b;
+-  Y = c == d;
+-  t1 = X ? e : f;
+-  t2 = Y ? f : e;
+-  t = t1 == t2;
+-  return t;
+-}
+-
+-/* Checks if pattern (X ? e : f) != (Y ? f : e) gets optimized. */
+-__GIMPLE()
+-_Bool f4_(int a, int b, int c, int d, int e, int f) {
+-  _Bool X;
+-  _Bool Y;
+-  _Bool t;
+-  int t1;
+-  int t2;
+-  X = a == b;
+-  Y = c == d;
+-  t1 = X ? e : f;
+-  t2 = Y ? f : e;
+-  t = t1 != t2;
+-  return t;
+-}
+-
+-/* Should generate one bit_xor_expr for each testcase. */
+-/* { dg-final { scan-tree-dump-not "cond_expr, "  "forwprop1" } } */
+-/* { dg-final { scan-tree-dump-times "bit_xor_expr, " 4 "forwprop1" } } */
+diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr111150.c b/gcc/testsuite/gcc.dg/tree-ssa/pr111150.c
+deleted file mode 100644
+index 568ae9e44b3d..000000000000
+--- a/gcc/testsuite/gcc.dg/tree-ssa/pr111150.c
++++ /dev/null
+@@ -1,22 +0,0 @@
+-/* PR tree-optimization/111150 */
+-/* { dg-do compile } */
+-/* { dg-options "-O1 -fdump-tree-forwprop1 -Wno-psabi" } */
+-
+-typedef int v4si __attribute((__vector_size__(4 * sizeof(int))));
+-
+-/* Before the patch, VEC_COND_EXPR was generated for each statement in the
+-   function. This resulted in 3 VEC_COND_EXPR. */
+-v4si f1_(v4si a, v4si b, v4si c, v4si d) {
+-  v4si X = a == b;
+-  v4si Y = c == d;
+-  return (X != Y);
+-}
+-
+-v4si f2_(v4si a, v4si b, v4si c, v4si d) {
+-  v4si X = a == b;
+-  v4si Y = c == d;
+-  return (X == Y);
+-}
+-
+-/* For each testcase, should produce only one VEC_COND_EXPR for X^Y. */
+-/* { dg-final { scan-tree-dump-times " VEC_COND_EXPR " 2 "forwprop1" } } */
+
+base-commit: d5f1948640815a554d106542c2e91e4e117aa3bc
+-- 
+2.45.2
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 81978cb..93de595 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+7	29 July 2024
+
+	+ 79_all_PR116120-revert-match-pattern.patch
+
 6	22 July 2024
 
 	- 76_all_ppc_PR97367-power7-cell-altivec.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-01 14:40 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-01 14:40 UTC (permalink / raw
  To: gentoo-commits
commit:     26118e917fcb919778bc5634c6cd8072ff23c4f6
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  1 14:39:41 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Aug  1 14:39:41 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=26118e91
15.0.0: drop 79_all_PR116120-revert-match-pattern.patch
Part of it is fixed and the other part should be committed soon.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../79_all_PR116120-revert-match-pattern.patch     | 199 ---------------------
 15.0.0/gentoo/README.history                       |   4 +
 2 files changed, 4 insertions(+), 199 deletions(-)
diff --git a/15.0.0/gentoo/79_all_PR116120-revert-match-pattern.patch b/15.0.0/gentoo/79_all_PR116120-revert-match-pattern.patch
deleted file mode 100644
index 6d5b542..0000000
--- a/15.0.0/gentoo/79_all_PR116120-revert-match-pattern.patch
+++ /dev/null
@@ -1,199 +0,0 @@
-From fd07aecb306c682e1d7255fc01c6c02f3ca4f6f8 Mon Sep 17 00:00:00 2001
-Message-ID: <fd07aecb306c682e1d7255fc01c6c02f3ca4f6f8.1722209590.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Mon, 29 Jul 2024 00:32:52 +0100
-Subject: [PATCH] Revert "MATCH: Simplify (a ? x : y) eq/ne (b ? x : y)
- [PR111150]"
-
-This reverts commit 44fcc1ca11e7ea35dc9fb25a5317346bc1eaf7b2.
-
-Avoid a reported & debugged miscompilation until it gets fixed.
-
-Bug: https://gcc.gnu.org/PR116120
----
- gcc/match.pd                               | 15 -----
- gcc/testsuite/g++.dg/tree-ssa/pr111150.C   | 34 ----------
- gcc/testsuite/gcc.dg/tree-ssa/pr111150-1.c | 72 ----------------------
- gcc/testsuite/gcc.dg/tree-ssa/pr111150.c   | 22 -------
- 4 files changed, 143 deletions(-)
- delete mode 100644 gcc/testsuite/g++.dg/tree-ssa/pr111150.C
- delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/pr111150-1.c
- delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/pr111150.c
-
-diff --git a/gcc/match.pd b/gcc/match.pd
-index 1c8601229e3d..b8d0ebee08db 100644
---- a/gcc/match.pd
-+++ b/gcc/match.pd
-@@ -5632,21 +5632,6 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
-   (vec_cond (bit_and (bit_not @0) @1) @2 @3)))
- #endif
- 
--/* (a ? x : y) != (b ? x : y) --> (a^b) ? TRUE  : FALSE */
--/* (a ? x : y) == (b ? x : y) --> (a^b) ? FALSE : TRUE  */
--/* (a ? x : y) != (b ? y : x) --> (a^b) ? FALSE : TRUE  */
--/* (a ? x : y) == (b ? y : x) --> (a^b) ? TRUE  : FALSE */
--(for cnd (cond vec_cond)
-- (for eqne (eq ne)
--  (simplify
--   (eqne:c (cnd @0 @1 @2) (cnd @3 @1 @2))
--    (cnd (bit_xor @0 @3) { constant_boolean_node (eqne == NE_EXPR, type); }
--     { constant_boolean_node (eqne != NE_EXPR, type); }))
--  (simplify
--   (eqne:c (cnd @0 @1 @2) (cnd @3 @2 @1))
--    (cnd (bit_xor @0 @3) { constant_boolean_node (eqne != NE_EXPR, type); }
--     { constant_boolean_node (eqne == NE_EXPR, type); }))))
--
- /* Canonicalize mask ? { 0, ... } : { -1, ...} to ~mask if the mask
-    types are compatible.  */
- (simplify
-diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr111150.C b/gcc/testsuite/g++.dg/tree-ssa/pr111150.C
-deleted file mode 100644
-index ac5d3ef15d83..000000000000
---- a/gcc/testsuite/g++.dg/tree-ssa/pr111150.C
-+++ /dev/null
-@@ -1,34 +0,0 @@
--/* PR tree-optimization/111150 */
--/* { dg-do compile } */
--/* { dg-options "-O1 -fdump-tree-forwprop1 -Wno-psabi" } */
--
--typedef int v4si __attribute((__vector_size__(4 * sizeof(int))));
--
--/* Before the patch, VEC_COND_EXPR was generated for each statement in the
--   function. This resulted in 3 VEC_COND_EXPR. */
--v4si f1_(v4si a, v4si b, v4si c, v4si d, v4si e, v4si f) {
--  v4si X = a == b ? e : f;
--  v4si Y = c == d ? e : f;
--  return (X != Y);
--}
--
--v4si f2_(v4si a, v4si b, v4si c, v4si d, v4si e, v4si f) {
--  v4si X = a == b ? e : f;
--  v4si Y = c == d ? e : f;
--  return (X == Y);
--}
--
--v4si f3_(v4si a, v4si b, v4si c, v4si d, v4si e, v4si f) {
--  v4si X = a == b ? e : f;
--  v4si Y = c == d ? f : e;
--  return (X != Y);
--}
--
--v4si f4_(v4si a, v4si b, v4si c, v4si d, v4si e, v4si f) {
--  v4si X = a == b ? e : f;
--  v4si Y = c == d ? f : e;
--  return (X == Y);
--}
--
--/* For each testcase, should produce only one VEC_COND_EXPR for X^Y. */
--/* { dg-final { scan-tree-dump-times " VEC_COND_EXPR " 4 "forwprop1" } } */
-diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr111150-1.c b/gcc/testsuite/gcc.dg/tree-ssa/pr111150-1.c
-deleted file mode 100644
-index 6f4b21ac6bcb..000000000000
---- a/gcc/testsuite/gcc.dg/tree-ssa/pr111150-1.c
-+++ /dev/null
-@@ -1,72 +0,0 @@
--/* PR tree-optimization/111150 */
--/* { dg-do compile } */
--/* { dg-options "-O1 -fgimple -fdump-tree-forwprop1-raw" } */
--
--/* Checks if pattern (X ? e : f) == (Y ? e : f) gets optimized. */
--__GIMPLE()
--_Bool f1_(int a, int b, int c, int d, int e, int f) {
--  _Bool X;
--  _Bool Y;
--  _Bool t;
--  int t1;
--  int t2;
--  X = a == b;
--  Y = c == d;
--  /* Before the patch cond_expr was generated for these 2 statements. */
--  t1 = X ? e : f;
--  t2 = Y ? e : f;
--  t = t1 == t2;
--  return t;
--}
--
--/* Checks if pattern (X ? e : f) != (Y ? e : f) gets optimized. */
--__GIMPLE()
--_Bool f2_(int a, int b, int c, int d, int e, int f) {
--  _Bool X;
--  _Bool Y;
--  _Bool t;
--  int t1;
--  int t2;
--  X = a == b;
--  Y = c == d;
--  t1 = X ? e : f;
--  t2 = Y ? e : f;
--  t = t1 != t2;
--  return t;
--}
--
--/* Checks if pattern (X ? e : f) == (Y ? f : e) gets optimized. */
--__GIMPLE()
--_Bool f3_(int a, int b, int c, int d, int e, int f) {
--  _Bool X;
--  _Bool Y;
--  _Bool t;
--  int t1;
--  int t2;
--  X = a == b;
--  Y = c == d;
--  t1 = X ? e : f;
--  t2 = Y ? f : e;
--  t = t1 == t2;
--  return t;
--}
--
--/* Checks if pattern (X ? e : f) != (Y ? f : e) gets optimized. */
--__GIMPLE()
--_Bool f4_(int a, int b, int c, int d, int e, int f) {
--  _Bool X;
--  _Bool Y;
--  _Bool t;
--  int t1;
--  int t2;
--  X = a == b;
--  Y = c == d;
--  t1 = X ? e : f;
--  t2 = Y ? f : e;
--  t = t1 != t2;
--  return t;
--}
--
--/* Should generate one bit_xor_expr for each testcase. */
--/* { dg-final { scan-tree-dump-not "cond_expr, "  "forwprop1" } } */
--/* { dg-final { scan-tree-dump-times "bit_xor_expr, " 4 "forwprop1" } } */
-diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr111150.c b/gcc/testsuite/gcc.dg/tree-ssa/pr111150.c
-deleted file mode 100644
-index 568ae9e44b3d..000000000000
---- a/gcc/testsuite/gcc.dg/tree-ssa/pr111150.c
-+++ /dev/null
-@@ -1,22 +0,0 @@
--/* PR tree-optimization/111150 */
--/* { dg-do compile } */
--/* { dg-options "-O1 -fdump-tree-forwprop1 -Wno-psabi" } */
--
--typedef int v4si __attribute((__vector_size__(4 * sizeof(int))));
--
--/* Before the patch, VEC_COND_EXPR was generated for each statement in the
--   function. This resulted in 3 VEC_COND_EXPR. */
--v4si f1_(v4si a, v4si b, v4si c, v4si d) {
--  v4si X = a == b;
--  v4si Y = c == d;
--  return (X != Y);
--}
--
--v4si f2_(v4si a, v4si b, v4si c, v4si d) {
--  v4si X = a == b;
--  v4si Y = c == d;
--  return (X == Y);
--}
--
--/* For each testcase, should produce only one VEC_COND_EXPR for X^Y. */
--/* { dg-final { scan-tree-dump-times " VEC_COND_EXPR " 2 "forwprop1" } } */
-
-base-commit: d5f1948640815a554d106542c2e91e4e117aa3bc
--- 
-2.45.2
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 93de595..793fd45 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+8	????
+
+	- 79_all_PR116120-revert-match-pattern.patch
+
 7	29 July 2024
 
 	+ 79_all_PR116120-revert-match-pattern.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-02 20:39 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-02 20:39 UTC (permalink / raw
  To: gentoo-commits
commit:     831195db0373e4954ff47452375844caf997e34b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  2 20:39:09 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug  2 20:39:09 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=831195db
15.0.0: add 79_all_Revert-Make-may_trap_p_1-return-false-for-constant-p.patch
Bug: https://gcc.gnu.org/PR116200
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-may_trap_p_1-return-false-for-constant-p.patch | 98 ++++++++++++++++++++++
 1 file changed, 98 insertions(+)
diff --git a/15.0.0/gentoo/79_all_Revert-Make-may_trap_p_1-return-false-for-constant-p.patch b/15.0.0/gentoo/79_all_Revert-Make-may_trap_p_1-return-false-for-constant-p.patch
new file mode 100644
index 0000000..c65b792
--- /dev/null
+++ b/15.0.0/gentoo/79_all_Revert-Make-may_trap_p_1-return-false-for-constant-p.patch
@@ -0,0 +1,98 @@
+From 4def9ea5a1511d6adbbd15e59f2542326484454a Mon Sep 17 00:00:00 2001
+Message-ID: <4def9ea5a1511d6adbbd15e59f2542326484454a.1722631128.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Fri, 2 Aug 2024 21:38:28 +0100
+Subject: [PATCH] Revert "Make may_trap_p_1 return false for constant pool
+ references [PR116145]"
+
+This reverts commit ba730fd10934e4ca004251aa3748bf9da4d35e62.
+
+Bug: https://gcc.gnu.org/PR116200
+---
+ gcc/rtlanal.cc                                | 14 ++----
+ .../aarch64/sve/acle/general/pr116145.c       | 46 -------------------
+ 2 files changed, 4 insertions(+), 56 deletions(-)
+ delete mode 100644 gcc/testsuite/gcc.target/aarch64/sve/acle/general/pr116145.c
+
+diff --git a/gcc/rtlanal.cc b/gcc/rtlanal.cc
+index 893a6afbbc53..4158a531bdd7 100644
+--- a/gcc/rtlanal.cc
++++ b/gcc/rtlanal.cc
+@@ -3152,16 +3152,10 @@ may_trap_p_1 (const_rtx x, unsigned flags)
+ 	  && MEM_VOLATILE_P (x)
+ 	  && XEXP (x, 0) == stack_pointer_rtx)
+ 	return true;
+-      if (/* MEM_READONLY_P means that the memory is both statically
+-	     allocated and readonly, so MEM_NOTRAP_P should remain true
+-	     even if the memory reference is moved.  This is certainly
+-	     true for the important case of force_const_mem.
+-
+-	     Otherwise, MEM_NOTRAP_P only relates to the actual position
+-	     of the memory reference; moving it out of context such as
+-	     when moving code when optimizing, might cause its address
+-	     to become invalid.  */
+-	  (code_changed && !MEM_READONLY_P (x))
++      if (/* MEM_NOTRAP_P only relates to the actual position of the memory
++	     reference; moving it out of context such as when moving code
++	     when optimizing, might cause its address to become invalid.  */
++	  code_changed
+ 	  || !MEM_NOTRAP_P (x))
+ 	{
+ 	  poly_int64 size = MEM_SIZE_KNOWN_P (x) ? MEM_SIZE (x) : -1;
+diff --git a/gcc/testsuite/gcc.target/aarch64/sve/acle/general/pr116145.c b/gcc/testsuite/gcc.target/aarch64/sve/acle/general/pr116145.c
+deleted file mode 100644
+index a3d93d3e1c84..000000000000
+--- a/gcc/testsuite/gcc.target/aarch64/sve/acle/general/pr116145.c
++++ /dev/null
+@@ -1,46 +0,0 @@
+-// { dg-options "-O2" }
+-
+-#include <stdlib.h>
+-#include <arm_sve.h>
+-
+-#pragma GCC target "+sve2"
+-
+-typedef unsigned char uchar;
+-
+-const uchar *
+-search_line_fast (const uchar *s, const uchar *end)
+-{
+-  size_t VL = svcntb();
+-  svuint8_t arr1, arr2;
+-  svbool_t pc, pg = svptrue_b8();
+-
+-  // This should not be loaded inside the loop every time.
+-  arr2 = svreinterpret_u8(svdup_u32(0x0a0d5c3f));
+-
+-  for (; s+VL <= end; s += VL) {
+-    arr1 = svld1_u8(pg, s);
+-    pc = svmatch_u8(pg, arr1, arr2);
+-
+-    if (svptest_any(pg, pc)) {
+-      pc = svbrkb_z(pg, pc);
+-      return s+svcntp_b8(pg, pc);
+-    }
+-  }
+-
+-  // Handle remainder.
+-  if (s < end) {
+-    pg = svwhilelt_b8((size_t)s, (size_t)end);
+-
+-    arr1 = svld1_u8(pg, s);
+-    pc = svmatch_u8(pg, arr1, arr2);
+-
+-    if (svptest_any(pg, pc)) {
+-      pc = svbrkb_z(pg, pc);
+-      return s+svcntp_b8(pg, pc);
+-    }
+-  }
+-
+-  return end;
+-}
+-
+-// { dg-final { scan-assembler {:\n\tld1b\t[^\n]*\n\tmatch\t[^\n]*\n\tb\.} } }
+
+base-commit: 5ebfaf2d4994c124ce81aa0abd7eaa1529644749
+-- 
+2.45.2
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-05  1:51 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-05  1:51 UTC (permalink / raw
  To: gentoo-commits
commit:     2723607b796c54089f8004568fa060c476dc829d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  5 01:47:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug  5 01:47:39 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=2723607b
15.0.0: cut patchset 8
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 793fd45..2188207 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
-8	????
+8	5 August 2024
 
 	- 79_all_PR116120-revert-match-pattern.patch
+	+ 79_all_Revert-Make-may_trap_p_1-return-false-for-constant-p.patch
 
 7	29 July 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-05  1:54 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-05  1:54 UTC (permalink / raw
  To: gentoo-commits
commit:     01af1e42d008b379d7046adce4733b4d67acdcf0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  5 01:54:07 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug  5 01:54:07 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=01af1e42
15.0.0: re-enable -fext-dce at -O2
All known issues are fixed, let's get testing it again.
I have let Jeff know I spotted a test is failing on s390x at
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=115912#c21.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...gcc_don-t-enable-fext-dce-with-O2-for-now.patch | 34 ----------------------
 15.0.0/gentoo/README.history                       |  4 +++
 2 files changed, 4 insertions(+), 34 deletions(-)
diff --git a/15.0.0/gentoo/78_all_gcc_don-t-enable-fext-dce-with-O2-for-now.patch b/15.0.0/gentoo/78_all_gcc_don-t-enable-fext-dce-with-O2-for-now.patch
deleted file mode 100644
index 82c5535..0000000
--- a/15.0.0/gentoo/78_all_gcc_don-t-enable-fext-dce-with-O2-for-now.patch
+++ /dev/null
@@ -1,34 +0,0 @@
-From 86de2fd7550f75a318aa9819b115487cd850b4fc Mon Sep 17 00:00:00 2001
-From: Sam James <sam@gentoo.org>
-Date: Mon, 15 Jul 2024 00:32:18 +0100
-Subject: [PATCH] gcc: don't enable -fext-dce with -O2 for now
-
-There's too many bugs involving it for now.
-
-    gcc/
-            * opts.cc (default_options_table): Don't enable ext-dce at -O2
-
-Bug: https://gcc.gnu.org/PR115876
-Bug: https://gcc.gnu.org/PR115877
-Bug: https://gcc.gnu.org/PR115912
-Bug: https://gcc.gnu.org/PR115916
-Bug: https://gcc.gnu.org/PR115927
----
- gcc/opts.cc | 1 -
- 1 file changed, 1 deletion(-)
-
-diff --git a/gcc/opts.cc b/gcc/opts.cc
-index be90a632338f..e1a1bdf15822 100644
---- a/gcc/opts.cc
-+++ b/gcc/opts.cc
-@@ -634,7 +634,6 @@ static const struct default_options default_options_table[] =
-     { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
-     { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
-     { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
--    { OPT_LEVELS_2_PLUS, OPT_fext_dce, NULL, 1 },
-     { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
-     { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
-     { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
--- 
-2.45.2
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 2188207..a872a71 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+?	????
+
+	- 78_all_gcc_don-t-enable-fext-dce-with-O2-for-now.patch
+
 8	5 August 2024
 
 	- 79_all_PR116120-revert-match-pattern.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-05  9:09 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-05  9:09 UTC (permalink / raw
  To: gentoo-commits
commit:     767d91209f8983d23caae12e2337eca6c2b5dbdb
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  5 09:09:04 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug  5 09:09:04 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=767d9120
15.0.0: drop 79_all_Revert-Make-may_trap_p_1-return-false-for-constant-p.patch
It's been reverted upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-may_trap_p_1-return-false-for-constant-p.patch | 98 ----------------------
 1 file changed, 98 deletions(-)
diff --git a/15.0.0/gentoo/79_all_Revert-Make-may_trap_p_1-return-false-for-constant-p.patch b/15.0.0/gentoo/79_all_Revert-Make-may_trap_p_1-return-false-for-constant-p.patch
deleted file mode 100644
index c65b792..0000000
--- a/15.0.0/gentoo/79_all_Revert-Make-may_trap_p_1-return-false-for-constant-p.patch
+++ /dev/null
@@ -1,98 +0,0 @@
-From 4def9ea5a1511d6adbbd15e59f2542326484454a Mon Sep 17 00:00:00 2001
-Message-ID: <4def9ea5a1511d6adbbd15e59f2542326484454a.1722631128.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Fri, 2 Aug 2024 21:38:28 +0100
-Subject: [PATCH] Revert "Make may_trap_p_1 return false for constant pool
- references [PR116145]"
-
-This reverts commit ba730fd10934e4ca004251aa3748bf9da4d35e62.
-
-Bug: https://gcc.gnu.org/PR116200
----
- gcc/rtlanal.cc                                | 14 ++----
- .../aarch64/sve/acle/general/pr116145.c       | 46 -------------------
- 2 files changed, 4 insertions(+), 56 deletions(-)
- delete mode 100644 gcc/testsuite/gcc.target/aarch64/sve/acle/general/pr116145.c
-
-diff --git a/gcc/rtlanal.cc b/gcc/rtlanal.cc
-index 893a6afbbc53..4158a531bdd7 100644
---- a/gcc/rtlanal.cc
-+++ b/gcc/rtlanal.cc
-@@ -3152,16 +3152,10 @@ may_trap_p_1 (const_rtx x, unsigned flags)
- 	  && MEM_VOLATILE_P (x)
- 	  && XEXP (x, 0) == stack_pointer_rtx)
- 	return true;
--      if (/* MEM_READONLY_P means that the memory is both statically
--	     allocated and readonly, so MEM_NOTRAP_P should remain true
--	     even if the memory reference is moved.  This is certainly
--	     true for the important case of force_const_mem.
--
--	     Otherwise, MEM_NOTRAP_P only relates to the actual position
--	     of the memory reference; moving it out of context such as
--	     when moving code when optimizing, might cause its address
--	     to become invalid.  */
--	  (code_changed && !MEM_READONLY_P (x))
-+      if (/* MEM_NOTRAP_P only relates to the actual position of the memory
-+	     reference; moving it out of context such as when moving code
-+	     when optimizing, might cause its address to become invalid.  */
-+	  code_changed
- 	  || !MEM_NOTRAP_P (x))
- 	{
- 	  poly_int64 size = MEM_SIZE_KNOWN_P (x) ? MEM_SIZE (x) : -1;
-diff --git a/gcc/testsuite/gcc.target/aarch64/sve/acle/general/pr116145.c b/gcc/testsuite/gcc.target/aarch64/sve/acle/general/pr116145.c
-deleted file mode 100644
-index a3d93d3e1c84..000000000000
---- a/gcc/testsuite/gcc.target/aarch64/sve/acle/general/pr116145.c
-+++ /dev/null
-@@ -1,46 +0,0 @@
--// { dg-options "-O2" }
--
--#include <stdlib.h>
--#include <arm_sve.h>
--
--#pragma GCC target "+sve2"
--
--typedef unsigned char uchar;
--
--const uchar *
--search_line_fast (const uchar *s, const uchar *end)
--{
--  size_t VL = svcntb();
--  svuint8_t arr1, arr2;
--  svbool_t pc, pg = svptrue_b8();
--
--  // This should not be loaded inside the loop every time.
--  arr2 = svreinterpret_u8(svdup_u32(0x0a0d5c3f));
--
--  for (; s+VL <= end; s += VL) {
--    arr1 = svld1_u8(pg, s);
--    pc = svmatch_u8(pg, arr1, arr2);
--
--    if (svptest_any(pg, pc)) {
--      pc = svbrkb_z(pg, pc);
--      return s+svcntp_b8(pg, pc);
--    }
--  }
--
--  // Handle remainder.
--  if (s < end) {
--    pg = svwhilelt_b8((size_t)s, (size_t)end);
--
--    arr1 = svld1_u8(pg, s);
--    pc = svmatch_u8(pg, arr1, arr2);
--
--    if (svptest_any(pg, pc)) {
--      pc = svbrkb_z(pg, pc);
--      return s+svcntp_b8(pg, pc);
--    }
--  }
--
--  return end;
--}
--
--// { dg-final { scan-assembler {:\n\tld1b\t[^\n]*\n\tmatch\t[^\n]*\n\tb\.} } }
-
-base-commit: 5ebfaf2d4994c124ce81aa0abd7eaa1529644749
--- 
-2.45.2
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-08 11:03 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-08 11:03 UTC (permalink / raw
  To: gentoo-commits
commit:     66b7838fff9640206291c609dd07b2bc95c9f128
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  8 11:03:19 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Aug  8 11:03:19 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=66b7838f
15.0.0: add 31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...ortran-pass-Wcomplain-wrong-lang-where-ap.patch | 104 +++++++++++++++++++++
 1 file changed, 104 insertions(+)
diff --git a/15.0.0/gentoo/31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch b/15.0.0/gentoo/31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch
new file mode 100644
index 0000000..0bf9812
--- /dev/null
+++ b/15.0.0/gentoo/31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch
@@ -0,0 +1,104 @@
+From 1e216be94b87d607cafd6f35fd2ece5ba5004a76 Mon Sep 17 00:00:00 2001
+Message-ID: <1e216be94b87d607cafd6f35fd2ece5ba5004a76.1723114981.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Thu, 8 Aug 2024 12:00:41 +0100
+Subject: [PATCH] testsuite: fortran: pass -Wcomplain-wrong-lang where
+ appropriate
+
+These tests expect the diagnostic from -Wcomplain-wrong-lang but
+don't explicitly enable it. This causes issues if running the testsuite
+with -Wno-complain-wrong-lang.
+
+gcc/testsuite/ChangeLog:
+        * gfortran.dg/ISO_Fortran_binding_17.f90: Pass -Wcomplain-wrong-lang.
+        * gfortran.dg/c-interop/allocate-errors.f90: Likewise.
+        * gfortran.dg/c-interop/establish-errors.f90: Likewise.
+        * gfortran.dg/c-interop/section-errors.f90: Likewise.
+        * gfortran.dg/c-interop/select-errors.f90: Likewise.
+        * gfortran.dg/c-interop/setpointer-errors.f90: Likewise.
+---
+ gcc/testsuite/gfortran.dg/ISO_Fortran_binding_17.f90      | 2 +-
+ gcc/testsuite/gfortran.dg/c-interop/allocate-errors.f90   | 2 +-
+ gcc/testsuite/gfortran.dg/c-interop/establish-errors.f90  | 2 +-
+ gcc/testsuite/gfortran.dg/c-interop/section-errors.f90    | 2 +-
+ gcc/testsuite/gfortran.dg/c-interop/select-errors.f90     | 2 +-
+ gcc/testsuite/gfortran.dg/c-interop/setpointer-errors.f90 | 2 +-
+ 6 files changed, 6 insertions(+), 6 deletions(-)
+
+diff --git a/gcc/testsuite/gfortran.dg/ISO_Fortran_binding_17.f90 b/gcc/testsuite/gfortran.dg/ISO_Fortran_binding_17.f90
+index c399e710ce97..c321c7a61f54 100644
+--- a/gcc/testsuite/gfortran.dg/ISO_Fortran_binding_17.f90
++++ b/gcc/testsuite/gfortran.dg/ISO_Fortran_binding_17.f90
+@@ -1,6 +1,6 @@
+ ! { dg-do run }
+ ! { dg-additional-sources ISO_Fortran_binding_17.c }
+-! { dg-options "-fcheck=all" }
++! { dg-options "-Wcomplain-wrong-lang -fcheck=all" }
+ ! { dg-warning "command-line option '-fcheck=all' is valid for Fortran but not for C" "" { target *-*-* } 0 }
+ !
+ ! PR fortran/92470
+diff --git a/gcc/testsuite/gfortran.dg/c-interop/allocate-errors.f90 b/gcc/testsuite/gfortran.dg/c-interop/allocate-errors.f90
+index a58d05a33681..1cf3fbd9fdd7 100644
+--- a/gcc/testsuite/gfortran.dg/c-interop/allocate-errors.f90
++++ b/gcc/testsuite/gfortran.dg/c-interop/allocate-errors.f90
+@@ -1,6 +1,6 @@
+ ! { dg-do run }
+ ! { dg-additional-sources "allocate-errors-c.c dump-descriptors.c" }
+-! { dg-additional-options "-Wno-error -fcheck=all" }
++! { dg-additional-options "-Wno-error -Wcomplain-wrong-lang -fcheck=all" }
+ ! { dg-warning "command-line option '-fcheck=all' is valid for Fortran but not for C" "" { target *-*-* } 0 }
+ !
+ ! This program tests that the CFI_allocate and CFI_deallocate functions
+diff --git a/gcc/testsuite/gfortran.dg/c-interop/establish-errors.f90 b/gcc/testsuite/gfortran.dg/c-interop/establish-errors.f90
+index 307a2664b743..c505c1904c75 100644
+--- a/gcc/testsuite/gfortran.dg/c-interop/establish-errors.f90
++++ b/gcc/testsuite/gfortran.dg/c-interop/establish-errors.f90
+@@ -1,7 +1,7 @@
+ ! PR101317
+ ! { dg-do run }
+ ! { dg-additional-sources "establish-errors-c.c dump-descriptors.c" }
+-! { dg-additional-options "-Wno-error -fcheck=all" }
++! { dg-additional-options "-Wno-error -Wcomplain-wrong-lang -fcheck=all" }
+ ! { dg-warning "command-line option '-fcheck=all' is valid for Fortran but not for C" "" { target *-*-* } 0 }
+ !
+ ! This program tests that the CFI_establish function properly detects
+diff --git a/gcc/testsuite/gfortran.dg/c-interop/section-errors.f90 b/gcc/testsuite/gfortran.dg/c-interop/section-errors.f90
+index 28328b799b30..699fa8940849 100644
+--- a/gcc/testsuite/gfortran.dg/c-interop/section-errors.f90
++++ b/gcc/testsuite/gfortran.dg/c-interop/section-errors.f90
+@@ -1,6 +1,6 @@
+ ! { dg-do run }
+ ! { dg-additional-sources "section-errors-c.c dump-descriptors.c" }
+-! { dg-additional-options "-Wno-error -fcheck=all" }
++! { dg-additional-options "-Wno-error -Wcomplain-wrong-lang -fcheck=all" }
+ ! { dg-warning "command-line option '-fcheck=all' is valid for Fortran but not for C" "" { target *-*-* } 0 }
+ !
+ ! This program tests that the CFI_section function properly detects
+diff --git a/gcc/testsuite/gfortran.dg/c-interop/select-errors.f90 b/gcc/testsuite/gfortran.dg/c-interop/select-errors.f90
+index b719c9e68679..199f314ed359 100644
+--- a/gcc/testsuite/gfortran.dg/c-interop/select-errors.f90
++++ b/gcc/testsuite/gfortran.dg/c-interop/select-errors.f90
+@@ -1,6 +1,6 @@
+ ! { dg-do run }
+ ! { dg-additional-sources "select-errors-c.c dump-descriptors.c" }
+-! { dg-additional-options "-Wno-error -fcheck=all" }
++! { dg-additional-options "-Wno-error -Wcomplain-wrong-lang -fcheck=all" }
+ ! { dg-warning "command-line option '-fcheck=all' is valid for Fortran but not for C" "" { target *-*-* } 0 }
+ !
+ ! This program tests that the CFI_select_part function properly detects
+diff --git a/gcc/testsuite/gfortran.dg/c-interop/setpointer-errors.f90 b/gcc/testsuite/gfortran.dg/c-interop/setpointer-errors.f90
+index 84a01ce16b12..3af7cc7f0e0f 100644
+--- a/gcc/testsuite/gfortran.dg/c-interop/setpointer-errors.f90
++++ b/gcc/testsuite/gfortran.dg/c-interop/setpointer-errors.f90
+@@ -1,7 +1,7 @@
+ ! PR 101317
+ ! { dg-do run }
+ ! { dg-additional-sources "setpointer-errors-c.c dump-descriptors.c" }
+-! { dg-additional-options "-Wno-error -fcheck=all" }
++! { dg-additional-options "-Wno-error -Wcomplain-wrong-lang -fcheck=all" }
+ ! { dg-warning "command-line option '-fcheck=all' is valid for Fortran but not for C" "" { target *-*-* } 0 }
+ !
+ ! This program tests that the CFI_setpointer function properly detects
+-- 
+2.45.2
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-08 11:06 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-08 11:06 UTC (permalink / raw
  To: gentoo-commits
commit:     bf4ef4b5f40ababd682716570dd5683d154844ca
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  8 11:06:47 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Aug  8 11:06:47 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=bf4ef4b5
15.0.0: add link to upstream discussion/question wrt tests
https://inbox.sourceware.org/gcc-patches/87v80cn24t.fsf <AT> gentoo.org/
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch   | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/15.0.0/gentoo/31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch b/15.0.0/gentoo/31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch
index 0bf9812..89e5a8b 100644
--- a/15.0.0/gentoo/31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch
+++ b/15.0.0/gentoo/31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch
@@ -1,3 +1,5 @@
+https://inbox.sourceware.org/gcc-patches/87v80cn24t.fsf@gentoo.org/
+
 From 1e216be94b87d607cafd6f35fd2ece5ba5004a76 Mon Sep 17 00:00:00 2001
 Message-ID: <1e216be94b87d607cafd6f35fd2ece5ba5004a76.1723114981.git.sam@gentoo.org>
 From: Sam James <sam@gentoo.org>
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-08 11:10 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-08 11:10 UTC (permalink / raw
  To: gentoo-commits
commit:     a8f25dda00d49c9a43b19d64fface4a570d6af07
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  8 11:09:50 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Aug  8 11:09:50 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=a8f25dda
15.0.0: add commit ref to eclass change too to patch
See d4c98533530d9478391b0593fd84cf37ac9c97cb.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch   | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/15.0.0/gentoo/31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch b/15.0.0/gentoo/31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch
index 89e5a8b..ba6d67f 100644
--- a/15.0.0/gentoo/31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch
+++ b/15.0.0/gentoo/31_all_testsuite-fortran-pass-Wcomplain-wrong-lang-where-ap.patch
@@ -1,5 +1,7 @@
 https://inbox.sourceware.org/gcc-patches/87v80cn24t.fsf@gentoo.org/
 
+See also d4c98533530d9478391b0593fd84cf37ac9c97cb in ::gentoo.
+
 From 1e216be94b87d607cafd6f35fd2ece5ba5004a76 Mon Sep 17 00:00:00 2001
 Message-ID: <1e216be94b87d607cafd6f35fd2ece5ba5004a76.1723114981.git.sam@gentoo.org>
 From: Sam James <sam@gentoo.org>
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-09 19:25 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-09 19:25 UTC (permalink / raw
  To: gentoo-commits
commit:     3dcc61086076d7c86d43dbad5961fadf1b944d72
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  9 19:24:37 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug  9 19:24:37 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=3dcc6108
15.0.0: add revert of LRA patch
See https://inbox.sourceware.org/gcc-patches/CA+=Sn1=_jL5P1Nbx4b7O-wYttpMsP4N545nk49rXntKnoJ7G-Q <AT> mail.gmail.com/.
It breaks arm64 bootstrap at least.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...emit-caller-save-register-spills-before-c.patch | 101 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 102 insertions(+)
diff --git a/15.0.0/gentoo/32_all_Revert-lra-emit-caller-save-register-spills-before-c.patch b/15.0.0/gentoo/32_all_Revert-lra-emit-caller-save-register-spills-before-c.patch
new file mode 100644
index 0000000..6cd1b43
--- /dev/null
+++ b/15.0.0/gentoo/32_all_Revert-lra-emit-caller-save-register-spills-before-c.patch
@@ -0,0 +1,101 @@
+From c67cc1d712f488a93d03dcfcda70e82250e13ab9 Mon Sep 17 00:00:00 2001
+Message-ID: <c67cc1d712f488a93d03dcfcda70e82250e13ab9.1723231445.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Fri, 9 Aug 2024 20:24:00 +0100
+Subject: [PATCH] Revert "lra: emit caller-save register spills before call
+ insn [PR116028]"
+
+This reverts commit 3c67a0fa1dd39a3378deb854a7fef0ff7fe38004.
+
+See https://inbox.sourceware.org/gcc-patches/CA+=Sn1=_jL5P1Nbx4b7O-wYttpMsP4N545nk49rXntKnoJ7G-Q@mail.gmail.com/.
+---
+ gcc/lra-constraints.cc                       | 28 +++-----------------
+ gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c |  2 +-
+ gcc/testsuite/gcc.dg/pr10474.c               |  2 +-
+ 3 files changed, 6 insertions(+), 26 deletions(-)
+
+diff --git a/gcc/lra-constraints.cc b/gcc/lra-constraints.cc
+index 28c1a877c003..92b343fa99a0 100644
+--- a/gcc/lra-constraints.cc
++++ b/gcc/lra-constraints.cc
+@@ -152,9 +152,6 @@ static machine_mode curr_operand_mode[MAX_RECOG_OPERANDS];
+    (e.g. constant) and whose subreg is given operand of the current
+    insn.  VOIDmode in all other cases.  */
+ static machine_mode original_subreg_reg_mode[MAX_RECOG_OPERANDS];
+-/* The nearest call insn for an insn on which split transformation
+-   will be done. The call insn is in the same EBB as the insn.  */
+-static rtx_insn *latest_call_insn;
+ 
+ \f
+ 
+@@ -6289,25 +6286,10 @@ split_reg (bool before_p, int original_regno, rtx_insn *insn,
+ 			 after_p ? restore : NULL,
+ 			 call_save_p
+ 			 ?  "Add reg<-save" : "Add reg<-split");
+-  if (call_save_p && latest_call_insn != NULL)
+-    /* PR116028: If original_regno is a pseudo that has been assigned a
+-       call-save hard register, then emit the spill insn before the call
+-       insn 'latest_call_insn' instead of adjacent to 'insn'. If 'insn'
+-       and 'latest_call_insn' belong to the same EBB but to two separate
+-       BBs, and if 'insn' is present in the entry BB, then generating the
+-       spill insn in the entry BB can prevent shrink wrap from happening.
+-       This is because the spill insn references the stack pointer and
+-       hence the prolog gets generated in the entry BB itself. It is
+-       also more efficient to generate the spill before
+-       'latest_call_insn' as the spill now occurs only in the path
+-       containing the call.  */
+-    lra_process_new_insns (PREV_INSN (latest_call_insn), NULL, save,
+-			   "Add save<-reg");
+-  else
+-    lra_process_new_insns (insn, before_p ? save : NULL,
+-			   before_p ? NULL : save,
+-			   call_save_p
+-			   ?  "Add save<-reg" : "Add split<-reg");
++  lra_process_new_insns (insn, before_p ? save : NULL,
++			 before_p ? NULL : save,
++			 call_save_p
++			 ?  "Add save<-reg" : "Add split<-reg");
+   if (nregs > 1 || original_regno < FIRST_PSEUDO_REGISTER)
+     /* If we are trying to split multi-register.  We should check
+        conflicts on the next assignment sub-pass.  IRA can allocate on
+@@ -6791,7 +6773,6 @@ inherit_in_ebb (rtx_insn *head, rtx_insn *tail)
+   last_processed_bb = NULL;
+   CLEAR_HARD_REG_SET (potential_reload_hard_regs);
+   live_hard_regs = eliminable_regset | lra_no_alloc_regs;
+-  latest_call_insn = NULL;
+   /* We don't process new insns generated in the loop.	*/
+   for (curr_insn = tail; curr_insn != PREV_INSN (head); curr_insn = prev_insn)
+     {
+@@ -7004,7 +6985,6 @@ inherit_in_ebb (rtx_insn *head, rtx_insn *tail)
+ 	      last_call_for_abi[callee_abi.id ()] = calls_num;
+ 	      full_and_partial_call_clobbers
+ 		|= callee_abi.full_and_partial_reg_clobbers ();
+-	      latest_call_insn = curr_insn;
+ 	      if ((cheap = find_reg_note (curr_insn,
+ 					  REG_RETURNED, NULL_RTX)) != NULL_RTX
+ 		  && ((cheap = XEXP (cheap, 0)), true)
+diff --git a/gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c b/gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c
+index 8c150972f952..a95637abbe54 100644
+--- a/gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c
++++ b/gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c
+@@ -26,4 +26,4 @@ bar (long a)
+ 
+ /* { dg-final { scan-rtl-dump "Will split live ranges of parameters" "ira" } } */
+ /* { dg-final { scan-rtl-dump "Split live-range of register" "ira" { xfail { ! aarch64*-*-* } } } } */
+-/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue" } } */
++/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue" { xfail powerpc*-*-* } } } */
+diff --git a/gcc/testsuite/gcc.dg/pr10474.c b/gcc/testsuite/gcc.dg/pr10474.c
+index b5393d5b6e3e..a4af536ec284 100644
+--- a/gcc/testsuite/gcc.dg/pr10474.c
++++ b/gcc/testsuite/gcc.dg/pr10474.c
+@@ -13,4 +13,4 @@ void f(int *i)
+ }
+ 
+ /* XFAIL due to PR70681.  */ 
+-/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue"  { xfail arm*-*-* } } } */
++/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue"  { xfail arm*-*-* powerpc*-*-* } } } */
+
+base-commit: 9e4da946c4263a4c89d5fc365b3c97ae244c5018
+-- 
+2.45.2
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index a872a71..3c55551 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 ?	????
 
 	- 78_all_gcc_don-t-enable-fext-dce-with-O2-for-now.patch
+	+ 32_all_Revert-lra-emit-caller-save-register-spills-before-c.patch
 
 8	5 August 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-09 19:47 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-09 19:47 UTC (permalink / raw
  To: gentoo-commits
commit:     b1db6e989802fb46fb5d242f68e3edbc0f0b2cd0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  9 19:46:45 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug  9 19:46:45 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b1db6e98
15.0.0: drop LRA revert
It's now reverted upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...emit-caller-save-register-spills-before-c.patch | 101 ---------------------
 1 file changed, 101 deletions(-)
diff --git a/15.0.0/gentoo/32_all_Revert-lra-emit-caller-save-register-spills-before-c.patch b/15.0.0/gentoo/32_all_Revert-lra-emit-caller-save-register-spills-before-c.patch
deleted file mode 100644
index 6cd1b43..0000000
--- a/15.0.0/gentoo/32_all_Revert-lra-emit-caller-save-register-spills-before-c.patch
+++ /dev/null
@@ -1,101 +0,0 @@
-From c67cc1d712f488a93d03dcfcda70e82250e13ab9 Mon Sep 17 00:00:00 2001
-Message-ID: <c67cc1d712f488a93d03dcfcda70e82250e13ab9.1723231445.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Fri, 9 Aug 2024 20:24:00 +0100
-Subject: [PATCH] Revert "lra: emit caller-save register spills before call
- insn [PR116028]"
-
-This reverts commit 3c67a0fa1dd39a3378deb854a7fef0ff7fe38004.
-
-See https://inbox.sourceware.org/gcc-patches/CA+=Sn1=_jL5P1Nbx4b7O-wYttpMsP4N545nk49rXntKnoJ7G-Q@mail.gmail.com/.
----
- gcc/lra-constraints.cc                       | 28 +++-----------------
- gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c |  2 +-
- gcc/testsuite/gcc.dg/pr10474.c               |  2 +-
- 3 files changed, 6 insertions(+), 26 deletions(-)
-
-diff --git a/gcc/lra-constraints.cc b/gcc/lra-constraints.cc
-index 28c1a877c003..92b343fa99a0 100644
---- a/gcc/lra-constraints.cc
-+++ b/gcc/lra-constraints.cc
-@@ -152,9 +152,6 @@ static machine_mode curr_operand_mode[MAX_RECOG_OPERANDS];
-    (e.g. constant) and whose subreg is given operand of the current
-    insn.  VOIDmode in all other cases.  */
- static machine_mode original_subreg_reg_mode[MAX_RECOG_OPERANDS];
--/* The nearest call insn for an insn on which split transformation
--   will be done. The call insn is in the same EBB as the insn.  */
--static rtx_insn *latest_call_insn;
- 
- \f
- 
-@@ -6289,25 +6286,10 @@ split_reg (bool before_p, int original_regno, rtx_insn *insn,
- 			 after_p ? restore : NULL,
- 			 call_save_p
- 			 ?  "Add reg<-save" : "Add reg<-split");
--  if (call_save_p && latest_call_insn != NULL)
--    /* PR116028: If original_regno is a pseudo that has been assigned a
--       call-save hard register, then emit the spill insn before the call
--       insn 'latest_call_insn' instead of adjacent to 'insn'. If 'insn'
--       and 'latest_call_insn' belong to the same EBB but to two separate
--       BBs, and if 'insn' is present in the entry BB, then generating the
--       spill insn in the entry BB can prevent shrink wrap from happening.
--       This is because the spill insn references the stack pointer and
--       hence the prolog gets generated in the entry BB itself. It is
--       also more efficient to generate the spill before
--       'latest_call_insn' as the spill now occurs only in the path
--       containing the call.  */
--    lra_process_new_insns (PREV_INSN (latest_call_insn), NULL, save,
--			   "Add save<-reg");
--  else
--    lra_process_new_insns (insn, before_p ? save : NULL,
--			   before_p ? NULL : save,
--			   call_save_p
--			   ?  "Add save<-reg" : "Add split<-reg");
-+  lra_process_new_insns (insn, before_p ? save : NULL,
-+			 before_p ? NULL : save,
-+			 call_save_p
-+			 ?  "Add save<-reg" : "Add split<-reg");
-   if (nregs > 1 || original_regno < FIRST_PSEUDO_REGISTER)
-     /* If we are trying to split multi-register.  We should check
-        conflicts on the next assignment sub-pass.  IRA can allocate on
-@@ -6791,7 +6773,6 @@ inherit_in_ebb (rtx_insn *head, rtx_insn *tail)
-   last_processed_bb = NULL;
-   CLEAR_HARD_REG_SET (potential_reload_hard_regs);
-   live_hard_regs = eliminable_regset | lra_no_alloc_regs;
--  latest_call_insn = NULL;
-   /* We don't process new insns generated in the loop.	*/
-   for (curr_insn = tail; curr_insn != PREV_INSN (head); curr_insn = prev_insn)
-     {
-@@ -7004,7 +6985,6 @@ inherit_in_ebb (rtx_insn *head, rtx_insn *tail)
- 	      last_call_for_abi[callee_abi.id ()] = calls_num;
- 	      full_and_partial_call_clobbers
- 		|= callee_abi.full_and_partial_reg_clobbers ();
--	      latest_call_insn = curr_insn;
- 	      if ((cheap = find_reg_note (curr_insn,
- 					  REG_RETURNED, NULL_RTX)) != NULL_RTX
- 		  && ((cheap = XEXP (cheap, 0)), true)
-diff --git a/gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c b/gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c
-index 8c150972f952..a95637abbe54 100644
---- a/gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c
-+++ b/gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c
-@@ -26,4 +26,4 @@ bar (long a)
- 
- /* { dg-final { scan-rtl-dump "Will split live ranges of parameters" "ira" } } */
- /* { dg-final { scan-rtl-dump "Split live-range of register" "ira" { xfail { ! aarch64*-*-* } } } } */
--/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue" } } */
-+/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue" { xfail powerpc*-*-* } } } */
-diff --git a/gcc/testsuite/gcc.dg/pr10474.c b/gcc/testsuite/gcc.dg/pr10474.c
-index b5393d5b6e3e..a4af536ec284 100644
---- a/gcc/testsuite/gcc.dg/pr10474.c
-+++ b/gcc/testsuite/gcc.dg/pr10474.c
-@@ -13,4 +13,4 @@ void f(int *i)
- }
- 
- /* XFAIL due to PR70681.  */ 
--/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue"  { xfail arm*-*-* } } } */
-+/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue"  { xfail arm*-*-* powerpc*-*-* } } } */
-
-base-commit: 9e4da946c4263a4c89d5fc365b3c97ae244c5018
--- 
-2.45.2
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-09 19:54 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-09 19:54 UTC (permalink / raw
  To: gentoo-commits
commit:     5a1f790fc4c95258c646243a30ba7adcecebcdcc
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  9 19:52:56 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug  9 19:52:56 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=5a1f790f
15.0.0: drop obsolete asprintf patch
Fixed upstream by r10-14-g6b3a5e8a3d18c8 and r6-1038-gf50f17e6707da0.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/07_all_libiberty-asprintf.patch | 18 ------------------
 15.0.0/gentoo/README.history                  |  2 +-
 2 files changed, 1 insertion(+), 19 deletions(-)
diff --git a/15.0.0/gentoo/07_all_libiberty-asprintf.patch b/15.0.0/gentoo/07_all_libiberty-asprintf.patch
deleted file mode 100644
index 1ed2ba3..0000000
--- a/15.0.0/gentoo/07_all_libiberty-asprintf.patch
+++ /dev/null
@@ -1,18 +0,0 @@
-2008-07-25  Magnus Granberg  <zorry@ume.nu>
-
-	* include/libiberty.h (asprintf): Don't declare if defined as a macro
-
---- a/include/libiberty.h
-+++ b/include/libiberty.h
-@@ -652,8 +652,11 @@ extern void *bsearch_r (const void *, const void *,
- /* Like sprintf but provides a pointer to malloc'd storage, which must
-    be freed by the caller.  */
- 
-+/* asprintf may be declared as a macro by glibc with __USE_FORTIFY_LEVEL.  */
-+#ifndef asprintf
- extern int asprintf (char **, const char *, ...) ATTRIBUTE_PRINTF_2;
- #endif
-+#endif
- 
- /* Like asprintf but allocates memory without fail. This works like
-    xmalloc.  */
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 3c55551..3d561ee 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,7 +1,7 @@
 ?	????
 
+	- 07_all_libiberty-asprintf.patch
 	- 78_all_gcc_don-t-enable-fext-dce-with-O2-for-now.patch
-	+ 32_all_Revert-lra-emit-caller-save-register-spills-before-c.patch
 
 8	5 August 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-09 19:54 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-09 19:54 UTC (permalink / raw
  To: gentoo-commits
commit:     ecc3ba06c22edee6b22d2e8e5e05031d18fa372a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  9 19:54:09 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug  9 19:54:22 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ecc3ba06
15.0.0: fix comment in 04_all_nossp-on-nostdlib.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/04_all_nossp-on-nostdlib.patch | 3 ++-
 15.0.0/gentoo/README.history                 | 1 +
 2 files changed, 3 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/04_all_nossp-on-nostdlib.patch b/15.0.0/gentoo/04_all_nossp-on-nostdlib.patch
index 30c5825..e17b6a3 100644
--- a/15.0.0/gentoo/04_all_nossp-on-nostdlib.patch
+++ b/15.0.0/gentoo/04_all_nossp-on-nostdlib.patch
@@ -1,4 +1,5 @@
-│Disable ssp on -nostdlib, -nodefaultlibs and -ffreestanding
+Disable ssp on -nostdlib, -nodefaultlibs and -ffreestanding
+
 https://bugs.gentoo.org/484714
 --- a/gcc/gcc.cc
 +++ b/gcc/gcc.cc
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 3d561ee..4b1d9e8 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 ?	????
 
+	U 04_all_nossp-on-nostdlib.patch
 	- 07_all_libiberty-asprintf.patch
 	- 78_all_gcc_don-t-enable-fext-dce-with-O2-for-now.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-11 22:40 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-11 22:40 UTC (permalink / raw
  To: gentoo-commits
commit:     743578d0de067c87f590c9886f14961bb429c1f4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 11 22:40:21 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Aug 11 22:40:21 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=743578d0
15.0.0: cut patchset 9
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 4b1d9e8..468a873 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-?	????
+9	11 August 2024
 
 	U 04_all_nossp-on-nostdlib.patch
 	- 07_all_libiberty-asprintf.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-14  2:57 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-14  2:57 UTC (permalink / raw
  To: gentoo-commits
commit:     70f5adef33e0620d934fc7fb0822e592e3ff04a1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 14 02:57:02 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug 14 02:57:02 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=70f5adef
15.0.0: add 32_all_genoutput-speedup.patch
Link: https://inbox.sourceware.org/gcc-patches/20240814021909.37082-1-cooper.qu <AT> linux.alibaba.com/
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/32_all_genoutput-speedup.patch | 247 +++++++++++++++++++++++++++
 15.0.0/gentoo/README.history                 |   4 +
 2 files changed, 251 insertions(+)
diff --git a/15.0.0/gentoo/32_all_genoutput-speedup.patch b/15.0.0/gentoo/32_all_genoutput-speedup.patch
new file mode 100644
index 0000000..a379bf8
--- /dev/null
+++ b/15.0.0/gentoo/32_all_genoutput-speedup.patch
@@ -0,0 +1,247 @@
+https://inbox.sourceware.org/gcc-patches/20240814021909.37082-1-cooper.qu@linux.alibaba.com/
+
+From 23ea354ab6c1faf858120b65a0114c5d0bbeaf6e Mon Sep 17 00:00:00 2001
+Message-ID: <23ea354ab6c1faf858120b65a0114c5d0bbeaf6e.1723604026.git.sam@gentoo.org>
+From: Xianmiao Qu <cooper.qu@linux.alibaba.com>
+Date: Wed, 14 Aug 2024 10:19:09 +0800
+Subject: [PATCH] genoutput: Accelerate the place_operands function.
+
+With the increase in the number of modes and patterns for some
+backend architectures, the place_operands function becomes a
+bottleneck int the speed of genoutput, and may even become a
+bottleneck int the overall speed of building the GCC project.
+This patch aims to accelerate the place_operands function,
+the optimizations it includes are:
+1. Use a hash table to store operand information,
+   improving the lookup time for the first operand.
+2. Move mode comparison to the beginning to avoid the scenarios of most strcmp.
+
+I tested the speed improvements for the following backends,
+	Improvement Ratio
+x86_64	197.9%
+aarch64	954.5%
+riscv	2578.6%
+If the build machine is slow, then this improvement can save a lot of time.
+
+I tested the genoutput output for x86_64/aarch64/riscv backends,
+and there was no difference compared to before the optimization,
+so this shouldn't introduce any functional issues.
+
+gcc/
+	* genoutput.cc (struct operand_data): Add member 'eq_next' to
+	point to the next member with the same hash value in the
+	hash table.
+	(compare_operands): Move the comparison of the mode to the very
+	beginning to accelerate the comparison of the two operands.
+	(struct operand_data_hasher): New, a class that takes into account
+	the necessary elements for comparing the equality of two operands
+	in its hash value.
+	(operand_data_hasher::hash): New.
+	(operand_data_hasher::equal): New.
+	(operand_datas): New, hash table of konwn pattern operands.
+	(place_operands): Use a hash table instead of traversing the array
+	to find the same operand.
+	(main): Add initialization of the hash table 'operand_datas'.
+---
+ gcc/genoutput.cc | 111 +++++++++++++++++++++++++++++++++++++----------
+ 1 file changed, 88 insertions(+), 23 deletions(-)
+
+diff --git a/gcc/genoutput.cc b/gcc/genoutput.cc
+index efd81766bb5b..16fd811b5dd5 100644
+--- a/gcc/genoutput.cc
++++ b/gcc/genoutput.cc
+@@ -91,6 +91,7 @@ along with GCC; see the file COPYING3.  If not see
+ #include "errors.h"
+ #include "read-md.h"
+ #include "gensupport.h"
++#include "hash-table.h"
+ 
+ /* No instruction can have more operands than this.  Sorry for this
+    arbitrary limit, but what machine will have an instruction with
+@@ -112,6 +113,8 @@ static int next_operand_number = 1;
+ struct operand_data
+ {
+   struct operand_data *next;
++  /* Point to the next member with the same hash value in the hash table.  */
++  struct operand_data *eq_next;
+   int index;
+   const char *predicate;
+   const char *constraint;
+@@ -127,7 +130,7 @@ struct operand_data
+ 
+ static struct operand_data null_operand =
+ {
+-  0, 0, "", "", E_VOIDmode, 0, 0, 0, 0, 0
++  0, 0, 0, "", "", E_VOIDmode, 0, 0, 0, 0, 0
+ };
+ 
+ static struct operand_data *odata = &null_operand;
+@@ -174,8 +177,8 @@ static void output_operand_data (void);
+ static void output_insn_data (void);
+ static void output_get_insn_name (void);
+ static void scan_operands (class data *, rtx, int, int);
+-static int compare_operands (struct operand_data *,
+-			     struct operand_data *);
++static int compare_operands (const struct operand_data *,
++			     const struct operand_data *);
+ static void place_operands (class data *);
+ static void process_template (class data *, const char *);
+ static void validate_insn_alternatives (class data *);
+@@ -528,10 +531,18 @@ scan_operands (class data *d, rtx part, int this_address_p,
+ /* Compare two operands for content equality.  */
+ 
+ static int
+-compare_operands (struct operand_data *d0, struct operand_data *d1)
++compare_operands (const struct operand_data *d0,
++		  const struct operand_data *d1)
+ {
+   const char *p0, *p1;
+ 
++  /* On one hand, comparing strings for predicate and constraint
++     is time-consuming, and on the other hand, the probability of
++     different modes is relatively high. Therefore, checking the mode
++     first can speed up the execution of the program.  */
++  if (d0->mode != d1->mode)
++    return 0;
++
+   p0 = d0->predicate;
+   if (!p0)
+     p0 = "";
+@@ -550,9 +561,6 @@ compare_operands (struct operand_data *d0, struct operand_data *d1)
+   if (strcmp (p0, p1) != 0)
+     return 0;
+ 
+-  if (d0->mode != d1->mode)
+-    return 0;
+-
+   if (d0->strict_low != d1->strict_low)
+     return 0;
+ 
+@@ -562,6 +570,46 @@ compare_operands (struct operand_data *d0, struct operand_data *d1)
+   return 1;
+ }
+ 
++/* This is a class that takes into account the necessary elements for
++   comparing the equality of two operands in its hash value.  */
++struct operand_data_hasher : nofree_ptr_hash <operand_data>
++{
++  static inline hashval_t hash (const operand_data *);
++  static inline bool equal (const operand_data *, const operand_data *);
++};
++
++hashval_t
++operand_data_hasher::hash (const operand_data * op_info)
++{
++  inchash::hash h;
++  const char *pred, *cons;
++
++  pred = op_info->predicate;
++  if (!pred)
++    pred = "";
++  h.add (pred, strlen (pred) + 1);
++
++  cons = op_info->constraint;
++  if (!cons)
++    cons = "";
++  h.add (cons, strlen (cons) + 1);
++
++  h.add_object (op_info->mode);
++  h.add_object (op_info->strict_low);
++  h.add_object (op_info->eliminable);
++  return h.end ();
++}
++
++bool
++operand_data_hasher::equal (const operand_data * op_info1,
++			    const operand_data * op_info2)
++{
++  return compare_operands (op_info1, op_info2);
++}
++
++/* Hashtable of konwn pattern operands.  */
++static hash_table<operand_data_hasher> *operand_datas;
++
+ /* Scan the list of operands we've already committed to output and either
+    find a subsequence that is the same, or allocate a new one at the end.  */
+ 
+@@ -569,6 +617,7 @@ static void
+ place_operands (class data *d)
+ {
+   struct operand_data *od, *od2;
++  struct operand_data **slot;
+   int i;
+ 
+   if (d->n_operands == 0)
+@@ -577,23 +626,24 @@ place_operands (class data *d)
+       return;
+     }
+ 
++  od = operand_datas->find (&d->operand[0]);
+   /* Brute force substring search.  */
+-  for (od = odata, i = 0; od; od = od->next, i = 0)
+-    if (compare_operands (od, &d->operand[0]))
+-      {
+-	od2 = od->next;
+-	i = 1;
+-	while (1)
+-	  {
+-	    if (i == d->n_operands)
+-	      goto full_match;
+-	    if (od2 == NULL)
+-	      goto partial_match;
+-	    if (! compare_operands (od2, &d->operand[i]))
+-	      break;
+-	    ++i, od2 = od2->next;
+-	  }
+-      }
++  for (; od; od = od->eq_next)
++    {
++      od2 = od->next;
++      i = 1;
++      while (1)
++	{
++	  if (i == d->n_operands)
++	    goto full_match;
++	  if (od2 == NULL)
++	    goto partial_match;
++	  if (! compare_operands (od2, &d->operand[i]))
++	    break;
++	  ++i, od2 = od2->next;
++	}
++    }
++  i = 0;
+ 
+   /* Either partial match at the end of the list, or no match.  In either
+      case, we tack on what operands are remaining to the end of the list.  */
+@@ -605,6 +655,20 @@ place_operands (class data *d)
+       *odata_end = od2;
+       odata_end = &od2->next;
+       od2->index = next_operand_number++;
++      /* Insert the operand_data variable OD2 into the hash table.
++	 If a variable with the same hash value already exists in
++	 the hash table, insert the element at the end of the
++	 linked list connected through the eq_next member.  */
++      slot = operand_datas->find_slot (od2, INSERT);
++      if (*slot)
++	{
++	  struct operand_data *last = (struct operand_data *) *slot;
++	  while (last->eq_next)
++	    last = last->eq_next;
++	  last->eq_next = od2;
++	}
++      else
++	*slot = od2;
+     }
+   *odata_end = NULL;
+   return;
+@@ -1049,6 +1113,7 @@ main (int argc, const char **argv)
+   progname = "genoutput";
+ 
+   init_insn_for_nothing ();
++  operand_datas = new hash_table<operand_data_hasher> (1024);
+ 
+   if (!init_rtx_reader_args (argc, argv))
+     return (FATAL_EXIT_CODE);
+-- 
+2.45.2
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 468a873..1849089 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+10	????
+
+	+ 32_all_genoutput-speedup.patch
+
 9	11 August 2024
 
 	U 04_all_nossp-on-nostdlib.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-14  9:48 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-14  9:48 UTC (permalink / raw
  To: gentoo-commits
commit:     b16c59c4a4df5f65d486023aedc4c5c7deef4f15
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 14 09:48:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug 14 09:48:15 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b16c59c4
15.0.0: drop now-upstream 32_all_genoutput-speedup.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/32_all_genoutput-speedup.patch | 247 ---------------------------
 1 file changed, 247 deletions(-)
diff --git a/15.0.0/gentoo/32_all_genoutput-speedup.patch b/15.0.0/gentoo/32_all_genoutput-speedup.patch
deleted file mode 100644
index a379bf8..0000000
--- a/15.0.0/gentoo/32_all_genoutput-speedup.patch
+++ /dev/null
@@ -1,247 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/20240814021909.37082-1-cooper.qu@linux.alibaba.com/
-
-From 23ea354ab6c1faf858120b65a0114c5d0bbeaf6e Mon Sep 17 00:00:00 2001
-Message-ID: <23ea354ab6c1faf858120b65a0114c5d0bbeaf6e.1723604026.git.sam@gentoo.org>
-From: Xianmiao Qu <cooper.qu@linux.alibaba.com>
-Date: Wed, 14 Aug 2024 10:19:09 +0800
-Subject: [PATCH] genoutput: Accelerate the place_operands function.
-
-With the increase in the number of modes and patterns for some
-backend architectures, the place_operands function becomes a
-bottleneck int the speed of genoutput, and may even become a
-bottleneck int the overall speed of building the GCC project.
-This patch aims to accelerate the place_operands function,
-the optimizations it includes are:
-1. Use a hash table to store operand information,
-   improving the lookup time for the first operand.
-2. Move mode comparison to the beginning to avoid the scenarios of most strcmp.
-
-I tested the speed improvements for the following backends,
-	Improvement Ratio
-x86_64	197.9%
-aarch64	954.5%
-riscv	2578.6%
-If the build machine is slow, then this improvement can save a lot of time.
-
-I tested the genoutput output for x86_64/aarch64/riscv backends,
-and there was no difference compared to before the optimization,
-so this shouldn't introduce any functional issues.
-
-gcc/
-	* genoutput.cc (struct operand_data): Add member 'eq_next' to
-	point to the next member with the same hash value in the
-	hash table.
-	(compare_operands): Move the comparison of the mode to the very
-	beginning to accelerate the comparison of the two operands.
-	(struct operand_data_hasher): New, a class that takes into account
-	the necessary elements for comparing the equality of two operands
-	in its hash value.
-	(operand_data_hasher::hash): New.
-	(operand_data_hasher::equal): New.
-	(operand_datas): New, hash table of konwn pattern operands.
-	(place_operands): Use a hash table instead of traversing the array
-	to find the same operand.
-	(main): Add initialization of the hash table 'operand_datas'.
----
- gcc/genoutput.cc | 111 +++++++++++++++++++++++++++++++++++++----------
- 1 file changed, 88 insertions(+), 23 deletions(-)
-
-diff --git a/gcc/genoutput.cc b/gcc/genoutput.cc
-index efd81766bb5b..16fd811b5dd5 100644
---- a/gcc/genoutput.cc
-+++ b/gcc/genoutput.cc
-@@ -91,6 +91,7 @@ along with GCC; see the file COPYING3.  If not see
- #include "errors.h"
- #include "read-md.h"
- #include "gensupport.h"
-+#include "hash-table.h"
- 
- /* No instruction can have more operands than this.  Sorry for this
-    arbitrary limit, but what machine will have an instruction with
-@@ -112,6 +113,8 @@ static int next_operand_number = 1;
- struct operand_data
- {
-   struct operand_data *next;
-+  /* Point to the next member with the same hash value in the hash table.  */
-+  struct operand_data *eq_next;
-   int index;
-   const char *predicate;
-   const char *constraint;
-@@ -127,7 +130,7 @@ struct operand_data
- 
- static struct operand_data null_operand =
- {
--  0, 0, "", "", E_VOIDmode, 0, 0, 0, 0, 0
-+  0, 0, 0, "", "", E_VOIDmode, 0, 0, 0, 0, 0
- };
- 
- static struct operand_data *odata = &null_operand;
-@@ -174,8 +177,8 @@ static void output_operand_data (void);
- static void output_insn_data (void);
- static void output_get_insn_name (void);
- static void scan_operands (class data *, rtx, int, int);
--static int compare_operands (struct operand_data *,
--			     struct operand_data *);
-+static int compare_operands (const struct operand_data *,
-+			     const struct operand_data *);
- static void place_operands (class data *);
- static void process_template (class data *, const char *);
- static void validate_insn_alternatives (class data *);
-@@ -528,10 +531,18 @@ scan_operands (class data *d, rtx part, int this_address_p,
- /* Compare two operands for content equality.  */
- 
- static int
--compare_operands (struct operand_data *d0, struct operand_data *d1)
-+compare_operands (const struct operand_data *d0,
-+		  const struct operand_data *d1)
- {
-   const char *p0, *p1;
- 
-+  /* On one hand, comparing strings for predicate and constraint
-+     is time-consuming, and on the other hand, the probability of
-+     different modes is relatively high. Therefore, checking the mode
-+     first can speed up the execution of the program.  */
-+  if (d0->mode != d1->mode)
-+    return 0;
-+
-   p0 = d0->predicate;
-   if (!p0)
-     p0 = "";
-@@ -550,9 +561,6 @@ compare_operands (struct operand_data *d0, struct operand_data *d1)
-   if (strcmp (p0, p1) != 0)
-     return 0;
- 
--  if (d0->mode != d1->mode)
--    return 0;
--
-   if (d0->strict_low != d1->strict_low)
-     return 0;
- 
-@@ -562,6 +570,46 @@ compare_operands (struct operand_data *d0, struct operand_data *d1)
-   return 1;
- }
- 
-+/* This is a class that takes into account the necessary elements for
-+   comparing the equality of two operands in its hash value.  */
-+struct operand_data_hasher : nofree_ptr_hash <operand_data>
-+{
-+  static inline hashval_t hash (const operand_data *);
-+  static inline bool equal (const operand_data *, const operand_data *);
-+};
-+
-+hashval_t
-+operand_data_hasher::hash (const operand_data * op_info)
-+{
-+  inchash::hash h;
-+  const char *pred, *cons;
-+
-+  pred = op_info->predicate;
-+  if (!pred)
-+    pred = "";
-+  h.add (pred, strlen (pred) + 1);
-+
-+  cons = op_info->constraint;
-+  if (!cons)
-+    cons = "";
-+  h.add (cons, strlen (cons) + 1);
-+
-+  h.add_object (op_info->mode);
-+  h.add_object (op_info->strict_low);
-+  h.add_object (op_info->eliminable);
-+  return h.end ();
-+}
-+
-+bool
-+operand_data_hasher::equal (const operand_data * op_info1,
-+			    const operand_data * op_info2)
-+{
-+  return compare_operands (op_info1, op_info2);
-+}
-+
-+/* Hashtable of konwn pattern operands.  */
-+static hash_table<operand_data_hasher> *operand_datas;
-+
- /* Scan the list of operands we've already committed to output and either
-    find a subsequence that is the same, or allocate a new one at the end.  */
- 
-@@ -569,6 +617,7 @@ static void
- place_operands (class data *d)
- {
-   struct operand_data *od, *od2;
-+  struct operand_data **slot;
-   int i;
- 
-   if (d->n_operands == 0)
-@@ -577,23 +626,24 @@ place_operands (class data *d)
-       return;
-     }
- 
-+  od = operand_datas->find (&d->operand[0]);
-   /* Brute force substring search.  */
--  for (od = odata, i = 0; od; od = od->next, i = 0)
--    if (compare_operands (od, &d->operand[0]))
--      {
--	od2 = od->next;
--	i = 1;
--	while (1)
--	  {
--	    if (i == d->n_operands)
--	      goto full_match;
--	    if (od2 == NULL)
--	      goto partial_match;
--	    if (! compare_operands (od2, &d->operand[i]))
--	      break;
--	    ++i, od2 = od2->next;
--	  }
--      }
-+  for (; od; od = od->eq_next)
-+    {
-+      od2 = od->next;
-+      i = 1;
-+      while (1)
-+	{
-+	  if (i == d->n_operands)
-+	    goto full_match;
-+	  if (od2 == NULL)
-+	    goto partial_match;
-+	  if (! compare_operands (od2, &d->operand[i]))
-+	    break;
-+	  ++i, od2 = od2->next;
-+	}
-+    }
-+  i = 0;
- 
-   /* Either partial match at the end of the list, or no match.  In either
-      case, we tack on what operands are remaining to the end of the list.  */
-@@ -605,6 +655,20 @@ place_operands (class data *d)
-       *odata_end = od2;
-       odata_end = &od2->next;
-       od2->index = next_operand_number++;
-+      /* Insert the operand_data variable OD2 into the hash table.
-+	 If a variable with the same hash value already exists in
-+	 the hash table, insert the element at the end of the
-+	 linked list connected through the eq_next member.  */
-+      slot = operand_datas->find_slot (od2, INSERT);
-+      if (*slot)
-+	{
-+	  struct operand_data *last = (struct operand_data *) *slot;
-+	  while (last->eq_next)
-+	    last = last->eq_next;
-+	  last->eq_next = od2;
-+	}
-+      else
-+	*slot = od2;
-     }
-   *odata_end = NULL;
-   return;
-@@ -1049,6 +1113,7 @@ main (int argc, const char **argv)
-   progname = "genoutput";
- 
-   init_insn_for_nothing ();
-+  operand_datas = new hash_table<operand_data_hasher> (1024);
- 
-   if (!init_rtx_reader_args (argc, argv))
-     return (FATAL_EXIT_CODE);
--- 
-2.45.2
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-19 18:43 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-19 18:43 UTC (permalink / raw
  To: gentoo-commits
commit:     b151680d1549ca7429f970c87b7c11987a351527
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 19 18:42:11 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 19 18:42:11 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b151680d
15.0.0: pull in phiopt fixes
Bug: https://bugs.gentoo.org/938203
Bug: https://bugs.gentoo.org/938200
Bug: https://bugs.gentoo.org/938199
Bug: https://bugs.gentoo.org/938198
Bug: https://bugs.gentoo.org/938196
Bug: https://bugs.gentoo.org/938194
Bug: https://bugs.gentoo.org/938193
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-for-non-const-functions-for-factor_out_c.patch | 100 +++++++++++++++++++++
 ...ct-non-gimple-val-inside-factor_out_condi.patch |  64 +++++++++++++
 15.0.0/gentoo/README.history                       |   5 +-
 3 files changed, 167 insertions(+), 2 deletions(-)
diff --git a/15.0.0/gentoo/32_all_phi-opt-Fix-for-non-const-functions-for-factor_out_c.patch b/15.0.0/gentoo/32_all_phi-opt-Fix-for-non-const-functions-for-factor_out_c.patch
new file mode 100644
index 0000000..1920001
--- /dev/null
+++ b/15.0.0/gentoo/32_all_phi-opt-Fix-for-non-const-functions-for-factor_out_c.patch
@@ -0,0 +1,100 @@
+From 8d5c584e088109e39402221f59c2330b24bed142 Mon Sep 17 00:00:00 2001
+Message-ID: <8d5c584e088109e39402221f59c2330b24bed142.1724092858.git.sam@gentoo.org>
+From: Andrew Pinski <quic_apinski@quicinc.com>
+Date: Mon, 19 Aug 2024 11:37:13 -0700
+Subject: [PATCH 1/2] phi-opt: Fix for non-const functions for
+ factor_out_conditional_operation [PR 116409]
+
+Currently maybe_push_res_to_seq does not handle non-const builtins (it does handle internal
+functions though). So we need to disable factoring out non-const builtins. This will be fixed in
+a better way later but this fixes the regression at hand and does not change what was goal on
+moving factor_out_conditional_operation over to use gimple_match_op.
+
+Bootstrapped and tested on x86_64-linux-gnu with no regressions.
+
+	PR  tree-optimization/116409
+
+gcc/ChangeLog:
+
+	* tree-ssa-phiopt.cc (factor_out_conditional_operation): Reject
+	non const builtins (except for internal functions).
+
+gcc/testsuite/ChangeLog:
+
+	* gcc.dg/torture/pr116409-1.c: New test.
+	* gcc.dg/torture/pr116409-2.c: New test.
+
+Signed-off-by: Andrew Pinski <quic_apinski@quicinc.com>
+---
+ gcc/testsuite/gcc.dg/torture/pr116409-1.c |  7 +++++++
+ gcc/testsuite/gcc.dg/torture/pr116409-2.c |  7 +++++++
+ gcc/tree-ssa-phiopt.cc                    | 18 ++++++++++++++++++
+ 3 files changed, 32 insertions(+)
+ create mode 100644 gcc/testsuite/gcc.dg/torture/pr116409-1.c
+ create mode 100644 gcc/testsuite/gcc.dg/torture/pr116409-2.c
+
+diff --git a/gcc/testsuite/gcc.dg/torture/pr116409-1.c b/gcc/testsuite/gcc.dg/torture/pr116409-1.c
+new file mode 100644
+index 000000000000..7bf8d49c9a01
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/torture/pr116409-1.c
+@@ -0,0 +1,7 @@
++/* { dg-do compile } */
++/* { dg-additional-options "-frounding-math -fno-math-errno" } */
++double f(int c, double a, double b) {
++  if (c)
++    return __builtin_sqrt(a);
++  return __builtin_sqrt(b);
++}
+diff --git a/gcc/testsuite/gcc.dg/torture/pr116409-2.c b/gcc/testsuite/gcc.dg/torture/pr116409-2.c
+new file mode 100644
+index 000000000000..c27f11312d98
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/torture/pr116409-2.c
+@@ -0,0 +1,7 @@
++/* { dg-do compile } */
++
++int f (int t, char *a, char *b) {
++  if (t)
++    return __builtin_strlen (a);
++  return __builtin_strlen (b);
++}
+diff --git a/gcc/tree-ssa-phiopt.cc b/gcc/tree-ssa-phiopt.cc
+index 2d4aba5b0872..770f3629fe1d 100644
+--- a/gcc/tree-ssa-phiopt.cc
++++ b/gcc/tree-ssa-phiopt.cc
+@@ -54,6 +54,7 @@ along with GCC; see the file COPYING3.  If not see
+ #include "dbgcnt.h"
+ #include "tree-ssa-propagate.h"
+ #include "tree-ssa-dce.h"
++#include "calls.h"
+ 
+ /* Return the singleton PHI in the SEQ of PHIs for edges E0 and E1. */
+ 
+@@ -367,6 +368,23 @@ factor_out_conditional_operation (edge e0, edge e1, gphi *phi,
+   if (!types_compatible_p (TREE_TYPE (new_arg0), TREE_TYPE (new_arg1)))
+     return NULL;
+ 
++  /* Function calls can only be const or an internal function
++     as maybe_push_res_to_seq only handles those currently.  */
++  if (!arg0_op.code.is_tree_code ())
++    {
++      auto fn = combined_fn (arg0_op.code);
++      if (!internal_fn_p (fn))
++	{
++	  tree decl = builtin_decl_implicit (as_builtin_fn (fn));
++	  if (!decl)
++	    return NULL;
++
++	  /* Non-const functions are not supported currently.  */
++	  if (!(flags_from_decl_or_type (decl) & ECF_CONST))
++	    return NULL;
++	}
++    }
++
+   /* Create a new PHI stmt.  */
+   result = PHI_RESULT (phi);
+   temp = make_ssa_name (TREE_TYPE (new_arg0), NULL);
+-- 
+2.46.0
+
diff --git a/15.0.0/gentoo/33_all_phiopt-Reject-non-gimple-val-inside-factor_out_condi.patch b/15.0.0/gentoo/33_all_phiopt-Reject-non-gimple-val-inside-factor_out_condi.patch
new file mode 100644
index 0000000..b3f96ae
--- /dev/null
+++ b/15.0.0/gentoo/33_all_phiopt-Reject-non-gimple-val-inside-factor_out_condi.patch
@@ -0,0 +1,64 @@
+From 555a5e896480884c3fe2c6c117654a798b8ffd3f Mon Sep 17 00:00:00 2001
+Message-ID: <555a5e896480884c3fe2c6c117654a798b8ffd3f.1724092858.git.sam@gentoo.org>
+In-Reply-To: <8d5c584e088109e39402221f59c2330b24bed142.1724092858.git.sam@gentoo.org>
+References: <8d5c584e088109e39402221f59c2330b24bed142.1724092858.git.sam@gentoo.org>
+From: Andrew Pinski <quic_apinski@quicinc.com>
+Date: Mon, 19 Aug 2024 11:37:14 -0700
+Subject: [PATCH 2/2] phiopt: Reject non gimple val inside
+ factor_out_conditional_operation [PR116412]
+
+After the conversion to use maybe_push_res_to_seq, sometimes (REALPART_EXPR
+and IMAGPART_EXPR and VCE) the argument will not be a gimple value and
+then phiopt here would create an invalid PHI.
+Just add a check for gimple val is the way to fix this.
+
+Bootstrapped and tested on x86_64-linux-gnu.
+
+	PR tree-optimization/116412
+
+gcc/ChangeLog:
+
+	* tree-ssa-phiopt.cc (factor_out_conditional_operation): Make sure new_arg0
+	and new_arg1 are both gimple values.
+
+gcc/testsuite/ChangeLog:
+
+	* gcc.dg/torture/pr116412-1.c: New test.
+
+Signed-off-by: Andrew Pinski <quic_apinski@quicinc.com>
+---
+ gcc/testsuite/gcc.dg/torture/pr116412-1.c | 6 ++++++
+ gcc/tree-ssa-phiopt.cc                    | 4 ++++
+ 2 files changed, 10 insertions(+)
+ create mode 100644 gcc/testsuite/gcc.dg/torture/pr116412-1.c
+
+diff --git a/gcc/testsuite/gcc.dg/torture/pr116412-1.c b/gcc/testsuite/gcc.dg/torture/pr116412-1.c
+new file mode 100644
+index 000000000000..3bc26ecd8b83
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/torture/pr116412-1.c
+@@ -0,0 +1,6 @@
++/* { dg-do compile } */
++double f(_Complex double a, _Complex double *b, int c)
++{
++  if (c) return __real__ a;
++  return __real__ *b;
++}
+diff --git a/gcc/tree-ssa-phiopt.cc b/gcc/tree-ssa-phiopt.cc
+index 770f3629fe1d..be95798a065b 100644
+--- a/gcc/tree-ssa-phiopt.cc
++++ b/gcc/tree-ssa-phiopt.cc
+@@ -368,6 +368,10 @@ factor_out_conditional_operation (edge e0, edge e1, gphi *phi,
+   if (!types_compatible_p (TREE_TYPE (new_arg0), TREE_TYPE (new_arg1)))
+     return NULL;
+ 
++  /* The new args need to be both gimple values. */
++  if (!is_gimple_val (new_arg0) || !is_gimple_val (new_arg1))
++    return NULL;
++
+   /* Function calls can only be const or an internal function
+      as maybe_push_res_to_seq only handles those currently.  */
+   if (!arg0_op.code.is_tree_code ())
+-- 
+2.46.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 1849089..0c430eb 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
-10	????
+10	19 August 2024
 
-	+ 32_all_genoutput-speedup.patch
+	+ 32_all_phi-opt-Fix-for-non-const-functions-for-factor_out_c.patch
+	+ 33_all_phiopt-Reject-non-gimple-val-inside-factor_out_condi.patch
 
 9	11 August 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-20 20:31 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-20 20:31 UTC (permalink / raw
  To: gentoo-commits
commit:     c9cf4331e4dfb52d6752adf48c161060fe6ef00a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 20 20:30:42 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Aug 20 20:30:42 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=c9cf4331
15.0.0: drop now-upstream phiopt patches
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-for-non-const-functions-for-factor_out_c.patch | 100 ---------------------
 ...ct-non-gimple-val-inside-factor_out_condi.patch |  64 -------------
 15.0.0/gentoo/README.history                       |   5 ++
 3 files changed, 5 insertions(+), 164 deletions(-)
diff --git a/15.0.0/gentoo/32_all_phi-opt-Fix-for-non-const-functions-for-factor_out_c.patch b/15.0.0/gentoo/32_all_phi-opt-Fix-for-non-const-functions-for-factor_out_c.patch
deleted file mode 100644
index 1920001..0000000
--- a/15.0.0/gentoo/32_all_phi-opt-Fix-for-non-const-functions-for-factor_out_c.patch
+++ /dev/null
@@ -1,100 +0,0 @@
-From 8d5c584e088109e39402221f59c2330b24bed142 Mon Sep 17 00:00:00 2001
-Message-ID: <8d5c584e088109e39402221f59c2330b24bed142.1724092858.git.sam@gentoo.org>
-From: Andrew Pinski <quic_apinski@quicinc.com>
-Date: Mon, 19 Aug 2024 11:37:13 -0700
-Subject: [PATCH 1/2] phi-opt: Fix for non-const functions for
- factor_out_conditional_operation [PR 116409]
-
-Currently maybe_push_res_to_seq does not handle non-const builtins (it does handle internal
-functions though). So we need to disable factoring out non-const builtins. This will be fixed in
-a better way later but this fixes the regression at hand and does not change what was goal on
-moving factor_out_conditional_operation over to use gimple_match_op.
-
-Bootstrapped and tested on x86_64-linux-gnu with no regressions.
-
-	PR  tree-optimization/116409
-
-gcc/ChangeLog:
-
-	* tree-ssa-phiopt.cc (factor_out_conditional_operation): Reject
-	non const builtins (except for internal functions).
-
-gcc/testsuite/ChangeLog:
-
-	* gcc.dg/torture/pr116409-1.c: New test.
-	* gcc.dg/torture/pr116409-2.c: New test.
-
-Signed-off-by: Andrew Pinski <quic_apinski@quicinc.com>
----
- gcc/testsuite/gcc.dg/torture/pr116409-1.c |  7 +++++++
- gcc/testsuite/gcc.dg/torture/pr116409-2.c |  7 +++++++
- gcc/tree-ssa-phiopt.cc                    | 18 ++++++++++++++++++
- 3 files changed, 32 insertions(+)
- create mode 100644 gcc/testsuite/gcc.dg/torture/pr116409-1.c
- create mode 100644 gcc/testsuite/gcc.dg/torture/pr116409-2.c
-
-diff --git a/gcc/testsuite/gcc.dg/torture/pr116409-1.c b/gcc/testsuite/gcc.dg/torture/pr116409-1.c
-new file mode 100644
-index 000000000000..7bf8d49c9a01
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/torture/pr116409-1.c
-@@ -0,0 +1,7 @@
-+/* { dg-do compile } */
-+/* { dg-additional-options "-frounding-math -fno-math-errno" } */
-+double f(int c, double a, double b) {
-+  if (c)
-+    return __builtin_sqrt(a);
-+  return __builtin_sqrt(b);
-+}
-diff --git a/gcc/testsuite/gcc.dg/torture/pr116409-2.c b/gcc/testsuite/gcc.dg/torture/pr116409-2.c
-new file mode 100644
-index 000000000000..c27f11312d98
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/torture/pr116409-2.c
-@@ -0,0 +1,7 @@
-+/* { dg-do compile } */
-+
-+int f (int t, char *a, char *b) {
-+  if (t)
-+    return __builtin_strlen (a);
-+  return __builtin_strlen (b);
-+}
-diff --git a/gcc/tree-ssa-phiopt.cc b/gcc/tree-ssa-phiopt.cc
-index 2d4aba5b0872..770f3629fe1d 100644
---- a/gcc/tree-ssa-phiopt.cc
-+++ b/gcc/tree-ssa-phiopt.cc
-@@ -54,6 +54,7 @@ along with GCC; see the file COPYING3.  If not see
- #include "dbgcnt.h"
- #include "tree-ssa-propagate.h"
- #include "tree-ssa-dce.h"
-+#include "calls.h"
- 
- /* Return the singleton PHI in the SEQ of PHIs for edges E0 and E1. */
- 
-@@ -367,6 +368,23 @@ factor_out_conditional_operation (edge e0, edge e1, gphi *phi,
-   if (!types_compatible_p (TREE_TYPE (new_arg0), TREE_TYPE (new_arg1)))
-     return NULL;
- 
-+  /* Function calls can only be const or an internal function
-+     as maybe_push_res_to_seq only handles those currently.  */
-+  if (!arg0_op.code.is_tree_code ())
-+    {
-+      auto fn = combined_fn (arg0_op.code);
-+      if (!internal_fn_p (fn))
-+	{
-+	  tree decl = builtin_decl_implicit (as_builtin_fn (fn));
-+	  if (!decl)
-+	    return NULL;
-+
-+	  /* Non-const functions are not supported currently.  */
-+	  if (!(flags_from_decl_or_type (decl) & ECF_CONST))
-+	    return NULL;
-+	}
-+    }
-+
-   /* Create a new PHI stmt.  */
-   result = PHI_RESULT (phi);
-   temp = make_ssa_name (TREE_TYPE (new_arg0), NULL);
--- 
-2.46.0
-
diff --git a/15.0.0/gentoo/33_all_phiopt-Reject-non-gimple-val-inside-factor_out_condi.patch b/15.0.0/gentoo/33_all_phiopt-Reject-non-gimple-val-inside-factor_out_condi.patch
deleted file mode 100644
index b3f96ae..0000000
--- a/15.0.0/gentoo/33_all_phiopt-Reject-non-gimple-val-inside-factor_out_condi.patch
+++ /dev/null
@@ -1,64 +0,0 @@
-From 555a5e896480884c3fe2c6c117654a798b8ffd3f Mon Sep 17 00:00:00 2001
-Message-ID: <555a5e896480884c3fe2c6c117654a798b8ffd3f.1724092858.git.sam@gentoo.org>
-In-Reply-To: <8d5c584e088109e39402221f59c2330b24bed142.1724092858.git.sam@gentoo.org>
-References: <8d5c584e088109e39402221f59c2330b24bed142.1724092858.git.sam@gentoo.org>
-From: Andrew Pinski <quic_apinski@quicinc.com>
-Date: Mon, 19 Aug 2024 11:37:14 -0700
-Subject: [PATCH 2/2] phiopt: Reject non gimple val inside
- factor_out_conditional_operation [PR116412]
-
-After the conversion to use maybe_push_res_to_seq, sometimes (REALPART_EXPR
-and IMAGPART_EXPR and VCE) the argument will not be a gimple value and
-then phiopt here would create an invalid PHI.
-Just add a check for gimple val is the way to fix this.
-
-Bootstrapped and tested on x86_64-linux-gnu.
-
-	PR tree-optimization/116412
-
-gcc/ChangeLog:
-
-	* tree-ssa-phiopt.cc (factor_out_conditional_operation): Make sure new_arg0
-	and new_arg1 are both gimple values.
-
-gcc/testsuite/ChangeLog:
-
-	* gcc.dg/torture/pr116412-1.c: New test.
-
-Signed-off-by: Andrew Pinski <quic_apinski@quicinc.com>
----
- gcc/testsuite/gcc.dg/torture/pr116412-1.c | 6 ++++++
- gcc/tree-ssa-phiopt.cc                    | 4 ++++
- 2 files changed, 10 insertions(+)
- create mode 100644 gcc/testsuite/gcc.dg/torture/pr116412-1.c
-
-diff --git a/gcc/testsuite/gcc.dg/torture/pr116412-1.c b/gcc/testsuite/gcc.dg/torture/pr116412-1.c
-new file mode 100644
-index 000000000000..3bc26ecd8b83
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/torture/pr116412-1.c
-@@ -0,0 +1,6 @@
-+/* { dg-do compile } */
-+double f(_Complex double a, _Complex double *b, int c)
-+{
-+  if (c) return __real__ a;
-+  return __real__ *b;
-+}
-diff --git a/gcc/tree-ssa-phiopt.cc b/gcc/tree-ssa-phiopt.cc
-index 770f3629fe1d..be95798a065b 100644
---- a/gcc/tree-ssa-phiopt.cc
-+++ b/gcc/tree-ssa-phiopt.cc
-@@ -368,6 +368,10 @@ factor_out_conditional_operation (edge e0, edge e1, gphi *phi,
-   if (!types_compatible_p (TREE_TYPE (new_arg0), TREE_TYPE (new_arg1)))
-     return NULL;
- 
-+  /* The new args need to be both gimple values. */
-+  if (!is_gimple_val (new_arg0) || !is_gimple_val (new_arg1))
-+    return NULL;
-+
-   /* Function calls can only be const or an internal function
-      as maybe_push_res_to_seq only handles those currently.  */
-   if (!arg0_op.code.is_tree_code ())
--- 
-2.46.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 0c430eb..82e55aa 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,8 @@
+11	????
+
+	- 32_all_phi-opt-Fix-for-non-const-functions-for-factor_out_c.patch
+	- 33_all_phiopt-Reject-non-gimple-val-inside-factor_out_condi.patch
+
 10	19 August 2024
 
 	+ 32_all_phi-opt-Fix-for-non-const-functions-for-factor_out_c.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-23 13:51 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-23 13:51 UTC (permalink / raw
  To: gentoo-commits
commit:     fec800d970afa89845479d5d6ad58140eaae5035
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  5 07:57:11 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 23 13:51:19 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=fec800d9
15.0.0: add 09_all_esysroot.patch
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/09_all_esysroot.patch | 67 +++++++++++++++++++++++++++++++++++++
 15.0.0/gentoo/README.history        |  1 +
 2 files changed, 68 insertions(+)
diff --git a/15.0.0/gentoo/09_all_esysroot.patch b/15.0.0/gentoo/09_all_esysroot.patch
new file mode 100644
index 0000000..80e0561
--- /dev/null
+++ b/15.0.0/gentoo/09_all_esysroot.patch
@@ -0,0 +1,67 @@
+From 71e048084d32811f6e17e73b6ebadfe550ef1193 Mon Sep 17 00:00:00 2001
+From: James Le Cuirot <chewi@gentoo.org>
+Date: Sun, 4 Aug 2024 17:02:06 +0100
+Subject: [PATCH] Allow setting target sysroot with ESYSROOT env var for
+ cross-compilers
+
+The variable is ignored for native compilers. The --sysroot command line
+option takes precedence.
+
+Signed-off-by: James Le Cuirot <chewi@gentoo.org>
+---
+ gcc/doc/invoke.texi | 10 ++++++++++
+ gcc/gcc.cc          | 10 ++++++++++
+ 2 files changed, 20 insertions(+)
+
+diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
+index 0fe99ca8e..434cf30e2 100644
+--- a/gcc/doc/invoke.texi
++++ b/gcc/doc/invoke.texi
+@@ -19230,6 +19230,10 @@ for this option.  If your linker does not support this option, the
+ header file aspect of @option{--sysroot} still works, but the
+ library aspect does not.
+ 
++On Gentoo Linux, this option can also be set for cross-compilers using the
++@env{ESYSROOT} environmnent variable.  The variable is ignored for native
++compilers.  The command line option takes precedence.
++
+ @opindex no-sysroot-suffix
+ @item --no-sysroot-suffix
+ For some targets, a suffix is added to the root directory specified
+@@ -37657,6 +37661,12 @@ using GCC also uses these directories when searching for ordinary
+ libraries for the @option{-l} option (but directories specified with
+ @option{-L} come first).
+ 
++@vindex ESYSROOT
++@item ESYSROOT
++On Gentoo Linux, this variable sets the logical root directory for headers and
++libraries for cross-compilers.  It is ignored for native compilers.  The
++@option{--sysroot} option takes precedence.
++
+ @vindex LANG
+ @cindex locale definition
+ @item LANG
+diff --git a/gcc/gcc.cc b/gcc/gcc.cc
+index abdb40bfe..956363ddb 100644
+--- a/gcc/gcc.cc
++++ b/gcc/gcc.cc
+@@ -5516,6 +5516,16 @@ process_command (unsigned int decoded_options_count,
+ 	      "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
+   free (tooldir_prefix);
+ 
++  if (*cross_compile == '1' && !target_system_root_changed)
++    {
++      const char *esysroot = env.get("ESYSROOT");
++      if (esysroot && esysroot[0] != '\0' && strcmp(esysroot, "/") != 0 && (!target_system_root || strcmp(esysroot, target_system_root) != 0))
++	{
++	  target_system_root = esysroot;
++	  target_system_root_changed = 1;
++	}
++    }
++
+ #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
+   /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
+      then consider it to relocate with the rest of the GCC installation
+-- 
+2.45.2
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 82e55aa..76096c4 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -2,6 +2,7 @@
 
 	- 32_all_phi-opt-Fix-for-non-const-functions-for-factor_out_c.patch
 	- 33_all_phiopt-Reject-non-gimple-val-inside-factor_out_condi.patch
+	+ 09_all_esysroot.patch
 
 10	19 August 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-26  6:24 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-26  6:24 UTC (permalink / raw
  To: gentoo-commits
commit:     b6fdeaf382dd20760fc3baf1ca9ff3db9f58c14d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 26 06:23:04 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 26 06:23:13 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b6fdeaf3
15.0.0: cut 11 patchset, add two patches
* Add an ICE fix for vectorization (PR116348)
* Fix bootstrap on x86 w/ debug info (PR116470)
Bug: https://gcc.gnu.org/PR116348
Bug: https://gcc.gnu.org/PR116470
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../gentoo/32_all_PR116470-debug-bootstrap.patch   | 78 ++++++++++++++++++++++
 15.0.0/gentoo/33_all_PR116348-vect.patch           | 78 ++++++++++++++++++++++
 15.0.0/gentoo/README.history                       |  4 +-
 3 files changed, 159 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/32_all_PR116470-debug-bootstrap.patch b/15.0.0/gentoo/32_all_PR116470-debug-bootstrap.patch
new file mode 100644
index 0000000..613cf4c
--- /dev/null
+++ b/15.0.0/gentoo/32_all_PR116470-debug-bootstrap.patch
@@ -0,0 +1,78 @@
+https://gcc.gnu.org/PR116470
+https://inbox.sourceware.org/gcc-patches/AS1PR01MB946587924CF9EFA4950ECBAFE48B2@AS1PR01MB9465.eurprd01.prod.exchangelabs.com/
+
+From 9c7050effd98d868d59fbd5ec7eeff1160eb05b8 Mon Sep 17 00:00:00 2001
+Message-ID: <9c7050effd98d868d59fbd5ec7eeff1160eb05b8.1724653254.git.sam@gentoo.org>
+From: Bernd Edlinger <bernd.edlinger@hotmail.de>
+Date: Mon, 26 Aug 2024 05:46:16 +0200
+Subject: [PATCH] Fix bootstap-errors due to enabling -gvariable-location-views
+
+This recent change triggered various bootsteap-errors, mostly on
+x86 targets because line info advance address entries were output
+in the wrong section table.
+The switch to the wrong line table happened in dwarfout_set_ignored_loc.
+It must use the same section as the earlier called
+dwarf2out_switch_text_section.
+
+But also ft32-elf was affected, because the assembler choked on
+something simple as ".2byte .LM2-.LM1", but fortunately it is
+able to use native location views, the configure test was just
+not executed because the ft32 "nop" instruction was missing.
+
+gcc/ChangeLog:
+
+PR debug/116470
+	* configure.ac: Add the "nop" instruction for cpu type ft32.
+	* configure: Regenerate.
+	* dwarf2out.cc (dwarf2out_set_ignored_loc): Use the correct
+	line info section.
+---
+ gcc/configure    | 2 +-
+ gcc/configure.ac | 2 +-
+ gcc/dwarf2out.cc | 2 +-
+ 3 files changed, 3 insertions(+), 3 deletions(-)
+
+diff --git a/gcc/configure b/gcc/configure
+index 557ea5fa3ac9..3d301b6ecd3d 100755
+--- a/gcc/configure
++++ b/gcc/configure
+@@ -31398,7 +31398,7 @@ esac
+ case "$cpu_type" in
+   aarch64 | alpha | arc | arm | avr | bfin | cris | csky | i386 | loongarch | m32c \
+   | m68k | microblaze | mips | nds32 | nios2 | pa | riscv | rs6000 | score | sparc \
+-  | visium | xstormy16 | xtensa)
++  | visium | xstormy16 | xtensa | ft32)
+     insn="nop"
+     ;;
+   ia64 | s390)
+diff --git a/gcc/configure.ac b/gcc/configure.ac
+index eaa01d0d7e56..8a2d2b0438e7 100644
+--- a/gcc/configure.ac
++++ b/gcc/configure.ac
+@@ -5610,7 +5610,7 @@ esac
+ case "$cpu_type" in
+   aarch64 | alpha | arc | arm | avr | bfin | cris | csky | i386 | loongarch | m32c \
+   | m68k | microblaze | mips | nds32 | nios2 | pa | riscv | rs6000 | score | sparc \
+-  | visium | xstormy16 | xtensa)
++  | visium | xstormy16 | xtensa | ft32)
+     insn="nop"
+     ;;
+   ia64 | s390)
+diff --git a/gcc/dwarf2out.cc b/gcc/dwarf2out.cc
+index 633900b035fe..3f040da33a63 100644
+--- a/gcc/dwarf2out.cc
++++ b/gcc/dwarf2out.cc
+@@ -28939,7 +28939,7 @@ dwarf2out_set_ignored_loc (unsigned int line, unsigned int column,
+   dw_fde_ref fde = cfun->fde;
+ 
+   fde->ignored_debug = false;
+-  set_cur_line_info_table (function_section (fde->decl));
++  set_cur_line_info_table (current_function_section ());
+ 
+   dwarf2out_source_line (line, column, filename, 0, true);
+ }
+
+base-commit: b4ac2c23d8745d98984954e88f02aa73f1c3594b
+-- 
+2.46.0
+
diff --git a/15.0.0/gentoo/33_all_PR116348-vect.patch b/15.0.0/gentoo/33_all_PR116348-vect.patch
new file mode 100644
index 0000000..623ce34
--- /dev/null
+++ b/15.0.0/gentoo/33_all_PR116348-vect.patch
@@ -0,0 +1,78 @@
+https://gcc.gnu.org/PR116348
+https://inbox.sourceware.org/gcc-patches/20240825185348.37025-1-xry111@xry111.site/T/#u
+
+From cc68092ef1bb1134f6d8ddf0281323658a4358ae Mon Sep 17 00:00:00 2001
+Message-ID: <cc68092ef1bb1134f6d8ddf0281323658a4358ae.1724653336.git.sam@gentoo.org>
+From: Xi Ruoyao <xry111@xry111.site>
+Date: Mon, 26 Aug 2024 02:53:13 +0800
+Subject: [PATCH] vect: Fix STMT_VINFO_DEF_TYPE check for odd/even widen mult
+ [PR116348]
+
+After fixing PR116142 some code started to trigger an ICE with -O3
+-march=znver4.  Per Richard Biener who actually made this fix:
+
+"supportable_widening_operation fails at transform time - that's likely
+because vectorizable_reduction "puns" defs to internal_def"
+
+so the check should use STMT_VINFO_REDUC_DEF instead of checking if
+STMT_VINFO_DEF_TYPE is vect_reduction_def.
+
+gcc/ChangeLog:
+
+	PR tree-optimization/PR116348
+	* tree-vect-stmts.cc (supportable_widening_operation): Use
+	STMT_VINFO_REDUC_DEF (x) instead of
+	STMT_VINFO_DEF_TYPE (x) == vect_reduction_def.
+
+gcc/testsuite/ChangeLog:
+
+	PR tree-optimization/PR116348
+	* gcc.c-torture/compile/pr116438.c: New test.
+
+Co-authored-by: Richard Biener <rguenther@suse.de>
+---
+ gcc/testsuite/gcc.c-torture/compile/pr116438.c | 14 ++++++++++++++
+ gcc/tree-vect-stmts.cc                         |  3 +--
+ 2 files changed, 15 insertions(+), 2 deletions(-)
+ create mode 100644 gcc/testsuite/gcc.c-torture/compile/pr116438.c
+
+diff --git a/gcc/testsuite/gcc.c-torture/compile/pr116438.c b/gcc/testsuite/gcc.c-torture/compile/pr116438.c
+new file mode 100644
+index 000000000000..97ab0181ab8b
+--- /dev/null
++++ b/gcc/testsuite/gcc.c-torture/compile/pr116438.c
+@@ -0,0 +1,14 @@
++/* { dg-additional-options "-march=znver4" { target x86_64-*-* i?86-*-* } } */
++
++int *a;
++int b;
++long long c, d;
++void
++e (int f)
++{
++  for (; f; f++)
++    {
++      d += (long long)a[f] * b;
++      c += (long long)a[f] * 3;
++    }
++}
+diff --git a/gcc/tree-vect-stmts.cc b/gcc/tree-vect-stmts.cc
+index 385e63163c24..9eb73a599339 100644
+--- a/gcc/tree-vect-stmts.cc
++++ b/gcc/tree-vect-stmts.cc
+@@ -14193,8 +14193,7 @@ supportable_widening_operation (vec_info *vinfo,
+              by STMT is only directly used in the reduction statement.  */
+ 	  tree lhs = gimple_assign_lhs (vect_orig_stmt (stmt_info)->stmt);
+ 	  stmt_vec_info use_stmt_info = loop_info->lookup_single_use (lhs);
+-	  if (use_stmt_info
+-	      && STMT_VINFO_DEF_TYPE (use_stmt_info) == vect_reduction_def)
++	  if (use_stmt_info && STMT_VINFO_REDUC_DEF (use_stmt_info))
+ 	    return true;
+         }
+       c1 = VEC_WIDEN_MULT_LO_EXPR;
+
+base-commit: b4ac2c23d8745d98984954e88f02aa73f1c3594b
+prerequisite-patch-id: 743f4e4444f9cac24e67abce2bda52d6a421d870
+-- 
+2.46.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 76096c4..728080e 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,8 +1,10 @@
-11	????
+11	26 August 2024
 
 	- 32_all_phi-opt-Fix-for-non-const-functions-for-factor_out_c.patch
 	- 33_all_phiopt-Reject-non-gimple-val-inside-factor_out_condi.patch
 	+ 09_all_esysroot.patch
+	+ 32_all_PR116470-debug-bootstrap.patch
+	+ 33_all_PR116348-vect.patch
 
 10	19 August 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-08-26 13:44 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-08-26 13:44 UTC (permalink / raw
  To: gentoo-commits
commit:     24f7b8a07ce29ac39d8d3245a1ba7f7abf3dcfa1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 26 13:43:58 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 26 13:43:58 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=24f7b8a0
15.0.0: drop now-upstream patches
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../gentoo/32_all_PR116470-debug-bootstrap.patch   | 78 ----------------------
 15.0.0/gentoo/33_all_PR116348-vect.patch           | 78 ----------------------
 15.0.0/gentoo/README.history                       |  5 ++
 3 files changed, 5 insertions(+), 156 deletions(-)
diff --git a/15.0.0/gentoo/32_all_PR116470-debug-bootstrap.patch b/15.0.0/gentoo/32_all_PR116470-debug-bootstrap.patch
deleted file mode 100644
index 613cf4c..0000000
--- a/15.0.0/gentoo/32_all_PR116470-debug-bootstrap.patch
+++ /dev/null
@@ -1,78 +0,0 @@
-https://gcc.gnu.org/PR116470
-https://inbox.sourceware.org/gcc-patches/AS1PR01MB946587924CF9EFA4950ECBAFE48B2@AS1PR01MB9465.eurprd01.prod.exchangelabs.com/
-
-From 9c7050effd98d868d59fbd5ec7eeff1160eb05b8 Mon Sep 17 00:00:00 2001
-Message-ID: <9c7050effd98d868d59fbd5ec7eeff1160eb05b8.1724653254.git.sam@gentoo.org>
-From: Bernd Edlinger <bernd.edlinger@hotmail.de>
-Date: Mon, 26 Aug 2024 05:46:16 +0200
-Subject: [PATCH] Fix bootstap-errors due to enabling -gvariable-location-views
-
-This recent change triggered various bootsteap-errors, mostly on
-x86 targets because line info advance address entries were output
-in the wrong section table.
-The switch to the wrong line table happened in dwarfout_set_ignored_loc.
-It must use the same section as the earlier called
-dwarf2out_switch_text_section.
-
-But also ft32-elf was affected, because the assembler choked on
-something simple as ".2byte .LM2-.LM1", but fortunately it is
-able to use native location views, the configure test was just
-not executed because the ft32 "nop" instruction was missing.
-
-gcc/ChangeLog:
-
-PR debug/116470
-	* configure.ac: Add the "nop" instruction for cpu type ft32.
-	* configure: Regenerate.
-	* dwarf2out.cc (dwarf2out_set_ignored_loc): Use the correct
-	line info section.
----
- gcc/configure    | 2 +-
- gcc/configure.ac | 2 +-
- gcc/dwarf2out.cc | 2 +-
- 3 files changed, 3 insertions(+), 3 deletions(-)
-
-diff --git a/gcc/configure b/gcc/configure
-index 557ea5fa3ac9..3d301b6ecd3d 100755
---- a/gcc/configure
-+++ b/gcc/configure
-@@ -31398,7 +31398,7 @@ esac
- case "$cpu_type" in
-   aarch64 | alpha | arc | arm | avr | bfin | cris | csky | i386 | loongarch | m32c \
-   | m68k | microblaze | mips | nds32 | nios2 | pa | riscv | rs6000 | score | sparc \
--  | visium | xstormy16 | xtensa)
-+  | visium | xstormy16 | xtensa | ft32)
-     insn="nop"
-     ;;
-   ia64 | s390)
-diff --git a/gcc/configure.ac b/gcc/configure.ac
-index eaa01d0d7e56..8a2d2b0438e7 100644
---- a/gcc/configure.ac
-+++ b/gcc/configure.ac
-@@ -5610,7 +5610,7 @@ esac
- case "$cpu_type" in
-   aarch64 | alpha | arc | arm | avr | bfin | cris | csky | i386 | loongarch | m32c \
-   | m68k | microblaze | mips | nds32 | nios2 | pa | riscv | rs6000 | score | sparc \
--  | visium | xstormy16 | xtensa)
-+  | visium | xstormy16 | xtensa | ft32)
-     insn="nop"
-     ;;
-   ia64 | s390)
-diff --git a/gcc/dwarf2out.cc b/gcc/dwarf2out.cc
-index 633900b035fe..3f040da33a63 100644
---- a/gcc/dwarf2out.cc
-+++ b/gcc/dwarf2out.cc
-@@ -28939,7 +28939,7 @@ dwarf2out_set_ignored_loc (unsigned int line, unsigned int column,
-   dw_fde_ref fde = cfun->fde;
- 
-   fde->ignored_debug = false;
--  set_cur_line_info_table (function_section (fde->decl));
-+  set_cur_line_info_table (current_function_section ());
- 
-   dwarf2out_source_line (line, column, filename, 0, true);
- }
-
-base-commit: b4ac2c23d8745d98984954e88f02aa73f1c3594b
--- 
-2.46.0
-
diff --git a/15.0.0/gentoo/33_all_PR116348-vect.patch b/15.0.0/gentoo/33_all_PR116348-vect.patch
deleted file mode 100644
index 623ce34..0000000
--- a/15.0.0/gentoo/33_all_PR116348-vect.patch
+++ /dev/null
@@ -1,78 +0,0 @@
-https://gcc.gnu.org/PR116348
-https://inbox.sourceware.org/gcc-patches/20240825185348.37025-1-xry111@xry111.site/T/#u
-
-From cc68092ef1bb1134f6d8ddf0281323658a4358ae Mon Sep 17 00:00:00 2001
-Message-ID: <cc68092ef1bb1134f6d8ddf0281323658a4358ae.1724653336.git.sam@gentoo.org>
-From: Xi Ruoyao <xry111@xry111.site>
-Date: Mon, 26 Aug 2024 02:53:13 +0800
-Subject: [PATCH] vect: Fix STMT_VINFO_DEF_TYPE check for odd/even widen mult
- [PR116348]
-
-After fixing PR116142 some code started to trigger an ICE with -O3
--march=znver4.  Per Richard Biener who actually made this fix:
-
-"supportable_widening_operation fails at transform time - that's likely
-because vectorizable_reduction "puns" defs to internal_def"
-
-so the check should use STMT_VINFO_REDUC_DEF instead of checking if
-STMT_VINFO_DEF_TYPE is vect_reduction_def.
-
-gcc/ChangeLog:
-
-	PR tree-optimization/PR116348
-	* tree-vect-stmts.cc (supportable_widening_operation): Use
-	STMT_VINFO_REDUC_DEF (x) instead of
-	STMT_VINFO_DEF_TYPE (x) == vect_reduction_def.
-
-gcc/testsuite/ChangeLog:
-
-	PR tree-optimization/PR116348
-	* gcc.c-torture/compile/pr116438.c: New test.
-
-Co-authored-by: Richard Biener <rguenther@suse.de>
----
- gcc/testsuite/gcc.c-torture/compile/pr116438.c | 14 ++++++++++++++
- gcc/tree-vect-stmts.cc                         |  3 +--
- 2 files changed, 15 insertions(+), 2 deletions(-)
- create mode 100644 gcc/testsuite/gcc.c-torture/compile/pr116438.c
-
-diff --git a/gcc/testsuite/gcc.c-torture/compile/pr116438.c b/gcc/testsuite/gcc.c-torture/compile/pr116438.c
-new file mode 100644
-index 000000000000..97ab0181ab8b
---- /dev/null
-+++ b/gcc/testsuite/gcc.c-torture/compile/pr116438.c
-@@ -0,0 +1,14 @@
-+/* { dg-additional-options "-march=znver4" { target x86_64-*-* i?86-*-* } } */
-+
-+int *a;
-+int b;
-+long long c, d;
-+void
-+e (int f)
-+{
-+  for (; f; f++)
-+    {
-+      d += (long long)a[f] * b;
-+      c += (long long)a[f] * 3;
-+    }
-+}
-diff --git a/gcc/tree-vect-stmts.cc b/gcc/tree-vect-stmts.cc
-index 385e63163c24..9eb73a599339 100644
---- a/gcc/tree-vect-stmts.cc
-+++ b/gcc/tree-vect-stmts.cc
-@@ -14193,8 +14193,7 @@ supportable_widening_operation (vec_info *vinfo,
-              by STMT is only directly used in the reduction statement.  */
- 	  tree lhs = gimple_assign_lhs (vect_orig_stmt (stmt_info)->stmt);
- 	  stmt_vec_info use_stmt_info = loop_info->lookup_single_use (lhs);
--	  if (use_stmt_info
--	      && STMT_VINFO_DEF_TYPE (use_stmt_info) == vect_reduction_def)
-+	  if (use_stmt_info && STMT_VINFO_REDUC_DEF (use_stmt_info))
- 	    return true;
-         }
-       c1 = VEC_WIDEN_MULT_LO_EXPR;
-
-base-commit: b4ac2c23d8745d98984954e88f02aa73f1c3594b
-prerequisite-patch-id: 743f4e4444f9cac24e67abce2bda52d6a421d870
--- 
-2.46.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 728080e..e1c375e 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,8 @@
+12	????
+
+	- 32_all_PR116470-debug-bootstrap.patch
+	- 33_all_PR116348-vect.patch
+
 11	26 August 2024
 
 	- 32_all_phi-opt-Fix-for-non-const-functions-for-factor_out_c.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-09-02  2:28 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-09-02  2:28 UTC (permalink / raw
  To: gentoo-commits
commit:     d676863b64b58bf73a7f26eea70f81aeba517b13
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep  2 02:28:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep  2 02:28:39 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=d676863b
15.0.0: cut patchset 12
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index e1c375e..a035c01 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-12	????
+12	1 September 2024
 
 	- 32_all_PR116470-debug-bootstrap.patch
 	- 33_all_PR116348-vect.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-09-23 15:23 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-09-23 15:23 UTC (permalink / raw
  To: gentoo-commits
commit:     690e151179e3dc40e99b3beeb551ac50b321d456
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 23 15:23:35 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 23 15:23:35 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=690e1511
15.0.0: add 70_all_middle-end-check-explicitly-for-external-or-constant.patch
Bug: https://gcc.gnu.org/PR116817
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...check-explicitly-for-external-or-constant.patch | 93 ++++++++++++++++++++++
 1 file changed, 93 insertions(+)
diff --git a/15.0.0/gentoo/70_all_middle-end-check-explicitly-for-external-or-constant.patch b/15.0.0/gentoo/70_all_middle-end-check-explicitly-for-external-or-constant.patch
new file mode 100644
index 0000000..6dcc1a4
--- /dev/null
+++ b/15.0.0/gentoo/70_all_middle-end-check-explicitly-for-external-or-constant.patch
@@ -0,0 +1,93 @@
+https://inbox.sourceware.org/gcc-patches/patch-18806-tamar@arm.com/T/#u
+https://gcc.gnu.org/PR116817
+
+From 9a5d1eb943dcaf26551b534eb62cbf1dd8443335 Mon Sep 17 00:00:00 2001
+Message-ID: <9a5d1eb943dcaf26551b534eb62cbf1dd8443335.1727104663.git.sam@gentoo.org>
+From: Tamar Christina <tamar.christina@arm.com>
+Date: Mon, 23 Sep 2024 15:29:52 +0100
+Subject: [PATCH] middle-end: check explicitly for external or constants when
+ checking for loop invariant [PR116817]
+
+Hi All,
+
+The previous check if a value was external was checking
+!vect_get_internal_def (vinfo, var) but this of course isn't completely right
+as they could reductions etc.
+
+This changes the check to just explicitly look at externals and constants.
+Note that reductions remain unhandled here, but we don't support codegen of
+boolean reductions today anyway.
+
+So at the time we do then this would have the be handled as well in lowering.
+
+Bootstrapped Regtested on aarch64-none-linux-gnu and no issues.
+
+Ok for master?
+
+Thanks,
+Tamar
+
+gcc/ChangeLog:
+
+	PR tree-optimization/116817
+	* tree-vect-patterns.cc (vect_recog_bool_pattern): Check for const or
+	externals.
+
+gcc/testsuite/ChangeLog:
+
+PR tree-optimization/116817
+	* g++.dg/vect/pr116817.cc: New test.
+---
+ gcc/testsuite/g++.dg/vect/pr116817.cc | 16 ++++++++++++++++
+ gcc/tree-vect-patterns.cc             |  5 ++++-
+ 2 files changed, 20 insertions(+), 1 deletion(-)
+ create mode 100644 gcc/testsuite/g++.dg/vect/pr116817.cc
+
+diff --git a/gcc/testsuite/g++.dg/vect/pr116817.cc b/gcc/testsuite/g++.dg/vect/pr116817.cc
+new file mode 100644
+index 00000000000..7e28982fb13
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/vect/pr116817.cc
+@@ -0,0 +1,16 @@
++/* { dg-do compile } */
++/* { dg-additional-options "-O3" } */
++
++int main_ulData0;
++unsigned *main_pSrcBuffer;
++int main(void) {
++  int iSrc = 0;
++  bool bData0;
++  for (; iSrc < 4; iSrc++) {
++    if (bData0)
++      main_pSrcBuffer[iSrc] = main_ulData0;
++    else
++      main_pSrcBuffer[iSrc] = 0;
++    bData0 = !bData0;
++  }
++}
+diff --git a/gcc/tree-vect-patterns.cc b/gcc/tree-vect-patterns.cc
+index e7e877dd2ad..b913d6de003 100644
+--- a/gcc/tree-vect-patterns.cc
++++ b/gcc/tree-vect-patterns.cc
+@@ -6062,12 +6062,15 @@ vect_recog_bool_pattern (vec_info *vinfo,
+       if (get_vectype_for_scalar_type (vinfo, type) == NULL_TREE)
+ 	return NULL;
+ 
++      stmt_vec_info var_def_info = vinfo->lookup_def (var);
+       if (check_bool_pattern (var, vinfo, bool_stmts))
+ 	var = adjust_bool_stmts (vinfo, bool_stmts, type, stmt_vinfo);
+       else if (integer_type_for_mask (var, vinfo))
+ 	return NULL;
+       else if (TREE_CODE (TREE_TYPE (var)) == BOOLEAN_TYPE
+-	       && !vect_get_internal_def (vinfo, var))
++	       && var_def_info
++	       && (STMT_VINFO_DEF_TYPE (var_def_info) == vect_external_def
++		   || STMT_VINFO_DEF_TYPE (var_def_info) == vect_constant_def))
+ 	{
+ 	  /* If the condition is already a boolean then manually convert it to a
+ 	     mask of the given integer type but don't set a vectype.  */
+
+base-commit: 358db2e3ed4acf44282d1d9ebbc4a1a3b6e38d21
+-- 
+2.46.1
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-09-24  1:41 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-09-24  1:41 UTC (permalink / raw
  To: gentoo-commits
commit:     3e1c7a2699f90793d9bf7107cb0b5943ba7c76c1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 24 01:41:22 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Sep 24 01:41:22 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=3e1c7a26
15.0.0: update 70_all_middle-end-check-explicitly-for-external-or-constant.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...middle-end-check-explicitly-for-external-or-constant.patch | 11 +++--------
 1 file changed, 3 insertions(+), 8 deletions(-)
diff --git a/15.0.0/gentoo/70_all_middle-end-check-explicitly-for-external-or-constant.patch b/15.0.0/gentoo/70_all_middle-end-check-explicitly-for-external-or-constant.patch
index 6dcc1a4..7dcf89d 100644
--- a/15.0.0/gentoo/70_all_middle-end-check-explicitly-for-external-or-constant.patch
+++ b/15.0.0/gentoo/70_all_middle-end-check-explicitly-for-external-or-constant.patch
@@ -66,7 +66,7 @@ index 00000000000..7e28982fb13
 +  }
 +}
 diff --git a/gcc/tree-vect-patterns.cc b/gcc/tree-vect-patterns.cc
-index e7e877dd2ad..b913d6de003 100644
+index e7e877dd2adb55262822f1660f8d92b42d44e6d0..f0298b2ab97a1e7dd0d943340e1389c3c0fa796e 100644
 --- a/gcc/tree-vect-patterns.cc
 +++ b/gcc/tree-vect-patterns.cc
 @@ -6062,12 +6062,15 @@ vect_recog_bool_pattern (vec_info *vinfo,
@@ -80,14 +80,9 @@ index e7e877dd2ad..b913d6de003 100644
  	return NULL;
        else if (TREE_CODE (TREE_TYPE (var)) == BOOLEAN_TYPE
 -	       && !vect_get_internal_def (vinfo, var))
-+	       && var_def_info
-+	       && (STMT_VINFO_DEF_TYPE (var_def_info) == vect_external_def
++	       && (!var_def_info
++		   || STMT_VINFO_DEF_TYPE (var_def_info) == vect_external_def
 +		   || STMT_VINFO_DEF_TYPE (var_def_info) == vect_constant_def))
  	{
  	  /* If the condition is already a boolean then manually convert it to a
  	     mask of the given integer type but don't set a vectype.  */
-
-base-commit: 358db2e3ed4acf44282d1d9ebbc4a1a3b6e38d21
--- 
-2.46.1
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-09-29 22:56 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-09-29 22:56 UTC (permalink / raw
  To: gentoo-commits
commit:     891af478cc93ae3e2e176ed9739166799b814a05
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 29 22:55:02 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep 29 22:55:28 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=891af478
15.0.0: add 71_all_PR116878-libcall.patch
It's been approved but not yet merged.
Bug: https://gcc.gnu.org/PR116616
Bug: https://gcc.gnu.org/PR116878
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/71_all_PR116878-libcall.patch | 215 ++++++++++++++++++++++++++++
 15.0.0/gentoo/README.history                |   4 +
 2 files changed, 219 insertions(+)
diff --git a/15.0.0/gentoo/71_all_PR116878-libcall.patch b/15.0.0/gentoo/71_all_PR116878-libcall.patch
new file mode 100644
index 0000000..781196d
--- /dev/null
+++ b/15.0.0/gentoo/71_all_PR116878-libcall.patch
@@ -0,0 +1,215 @@
+https://gcc.gnu.org/PR116878
+https://gcc.gnu.org/PR116616
+
+From b9883d33e6338b1a44247b3f8772a5e5d2757593 Mon Sep 17 00:00:00 2001
+Message-ID: <b9883d33e6338b1a44247b3f8772a5e5d2757593.1727650422.git.sam@gentoo.org>
+From: Filip Kastl <fkastl@suse.cz>
+Date: Tue, 10 Sep 2024 19:22:27 +0200
+Subject: [PATCH] gimple ssa: Don't use __builtin_popcount in switch exp
+ transform
+
+Switch exponential transformation in the switch conversion pass
+currently generates
+
+tmp1 = __builtin_popcount (var);
+tmp2 = tmp1 == 1;
+
+when inserting code to determine if var is power of two.  If the target
+doesn't support expanding the builtin as special instructions switch
+conversion relies on this whole pattern being expanded as bitmagic.
+However, it is possible that other GIMPLE optimizations move the two
+statements of the pattern apart.  In that case the builtin becomes a
+libgcc call in the final binary.  The call is slow and in case of
+freestanding programs can result in linking error (this bug was
+originally found while compiling Linux kernel).
+
+This patch modifies switch conversion to insert the bitmagic
+(var ^ (var - 1)) > (var - 1) instead of the builtin.
+
+gcc/ChangeLog:
+
+	PR tree-optimization/116616
+	* tree-switch-conversion.cc (can_pow2p): Remove this function.
+	(gen_pow2p): Generate bitmagic instead of a builtin.  Remove the
+	TYPE parameter.
+	(switch_conversion::is_exp_index_transform_viable): Don't call
+	can_pow2p.
+	(switch_conversion::exp_index_transform): Call gen_pow2p without
+	the TYPE parameter.
+	* tree-switch-conversion.h: Remove
+	m_exp_index_transform_pow2p_type.
+
+gcc/testsuite/ChangeLog:
+
+	PR tree-optimization/116616
+	* gcc.target/i386/switch-exp-transform-1.c: Don't test for
+	presence of the POPCOUNT internal fn call.
+
+Signed-off-by: Filip Kastl <fkastl@suse.cz>
+---
+ .../gcc.target/i386/switch-exp-transform-1.c  |  7 +-
+ gcc/tree-switch-conversion.cc                 | 84 +++++--------------
+ gcc/tree-switch-conversion.h                  |  6 +-
+ 3 files changed, 23 insertions(+), 74 deletions(-)
+
+diff --git a/gcc/testsuite/gcc.target/i386/switch-exp-transform-1.c b/gcc/testsuite/gcc.target/i386/switch-exp-transform-1.c
+index a8c9e03e515f..4832f5b52c33 100644
+--- a/gcc/testsuite/gcc.target/i386/switch-exp-transform-1.c
++++ b/gcc/testsuite/gcc.target/i386/switch-exp-transform-1.c
+@@ -1,10 +1,8 @@
+ /* { dg-do compile } */
+-/* { dg-options "-O2 -fdump-tree-switchconv -fdump-tree-widening_mul -mpopcnt -mbmi" } */
++/* { dg-options "-O2 -fdump-tree-switchconv -mbmi" } */
+ 
+ /* Checks that exponential index transform enables switch conversion to convert
+-   this switch into an array lookup.  Also checks that the "index variable is a
+-   power of two" check has been generated and that it has been later expanded
+-   into an internal function.  */
++   this switch into an array lookup.  */
+ 
+ int foo(unsigned bar)
+ {
+@@ -30,4 +28,3 @@ int foo(unsigned bar)
+ }
+ 
+ /* { dg-final { scan-tree-dump "CSWTCH" "switchconv" } } */
+-/* { dg-final { scan-tree-dump "POPCOUNT" "widening_mul" } } */
+diff --git a/gcc/tree-switch-conversion.cc b/gcc/tree-switch-conversion.cc
+index c1332a260943..00426d400006 100644
+--- a/gcc/tree-switch-conversion.cc
++++ b/gcc/tree-switch-conversion.cc
+@@ -133,75 +133,33 @@ gen_log2 (tree op, location_t loc, tree *result, tree type)
+   return stmts;
+ }
+ 
+-/* Is it possible to efficiently check that a value of TYPE is a power of 2?
+-
+-   If yes, returns TYPE.  If no, returns NULL_TREE.  May also return another
+-   type.  This indicates that logarithm of the variable can be computed but
+-   only after it is converted to this type.
+-
+-   Also see gen_pow2p.  */
+-
+-static tree
+-can_pow2p (tree type)
+-{
+-  /* __builtin_popcount supports the unsigned type or its long and long long
+-     variants.  Choose the smallest out of those that can still fit TYPE.  */
+-  int prec = TYPE_PRECISION (type);
+-  int i_prec = TYPE_PRECISION (unsigned_type_node);
+-  int li_prec = TYPE_PRECISION (long_unsigned_type_node);
+-  int lli_prec = TYPE_PRECISION (long_long_unsigned_type_node);
+-
+-  if (prec <= i_prec)
+-    return unsigned_type_node;
+-  else if (prec <= li_prec)
+-    return long_unsigned_type_node;
+-  else if (prec <= lli_prec)
+-    return long_long_unsigned_type_node;
+-  else
+-    return NULL_TREE;
+-}
+-
+-/* Build a sequence of gimple statements checking that OP is a power of 2.  Use
+-   special optabs if target supports them.  Return the result as a
+-   boolean_type_node ssa name through RESULT.  Assumes that OP's value will
+-   be non-negative.  The generated check may give arbitrary answer for negative
+-   values.
+-
+-   Before computing the check, OP may have to be converted to another type.
+-   This should be specified in TYPE.  Use can_pow2p to decide what this type
+-   should be.
+-
+-   Should only be used if can_pow2p returns true for type of OP.  */
++/* Build a sequence of gimple statements checking that OP is a power of 2.
++   Return the result as a boolean_type_node ssa name through RESULT.  Assumes
++   that OP's value will be non-negative.  The generated check may give
++   arbitrary answer for negative values.  */
+ 
+ static gimple_seq
+-gen_pow2p (tree op, location_t loc, tree *result, tree type)
++gen_pow2p (tree op, location_t loc, tree *result)
+ {
+   gimple_seq stmts = NULL;
+   gimple_stmt_iterator gsi = gsi_last (stmts);
+ 
+-  built_in_function fn;
+-  if (type == unsigned_type_node)
+-    fn = BUILT_IN_POPCOUNT;
+-  else if (type == long_unsigned_type_node)
+-    fn = BUILT_IN_POPCOUNTL;
+-  else
+-    {
+-      fn = BUILT_IN_POPCOUNTLL;
+-      gcc_checking_assert (type == long_long_unsigned_type_node);
+-    }
++  tree type = TREE_TYPE (op);
++  tree utype = unsigned_type_for (type);
+ 
+-  tree orig_type = TREE_TYPE (op);
++  /* Build (op ^ (op - 1)) > (op - 1).  */
+   tree tmp1;
+-  if (type != orig_type)
+-    tmp1 = gimple_convert (&gsi, false, GSI_NEW_STMT, loc, type, op);
+-  else
++  if (types_compatible_p (type, utype))
+     tmp1 = op;
+-  /* Build __builtin_popcount{l,ll} (op) == 1.  */
+-  tree tmp2 = gimple_build (&gsi, false, GSI_NEW_STMT, loc,
+-			    as_combined_fn (fn), integer_type_node, tmp1);
+-  *result = gimple_build (&gsi, false, GSI_NEW_STMT, loc, EQ_EXPR,
+-			  boolean_type_node, tmp2,
+-			  build_one_cst (integer_type_node));
++  else
++    tmp1 = gimple_convert (&gsi, false, GSI_NEW_STMT, loc, utype, op);
++  tree tmp2 = gimple_build (&gsi, false, GSI_NEW_STMT, loc, MINUS_EXPR, utype,
++			    tmp1, build_one_cst (utype));
++  tree tmp3 = gimple_build (&gsi, false, GSI_NEW_STMT, loc, BIT_XOR_EXPR,
++			    utype, tmp1, tmp2);
++  *result = gimple_build (&gsi, false, GSI_NEW_STMT, loc, GT_EXPR,
++			  boolean_type_node, tmp3, tmp2);
++
+   return stmts;
+ }
+ 
+@@ -371,9 +329,6 @@ switch_conversion::is_exp_index_transform_viable (gswitch *swtch)
+   m_exp_index_transform_log2_type = can_log2 (index_type, opt_type);
+   if (!m_exp_index_transform_log2_type)
+     return false;
+-  m_exp_index_transform_pow2p_type = can_pow2p (index_type);
+-  if (!m_exp_index_transform_pow2p_type)
+-    return false;
+ 
+   /* Check that each case label corresponds only to one value
+      (no case 1..3).  */
+@@ -467,8 +422,7 @@ switch_conversion::exp_index_transform (gswitch *swtch)
+   new_edge2->probability = profile_probability::even ();
+ 
+   tree tmp;
+-  gimple_seq stmts = gen_pow2p (index, UNKNOWN_LOCATION, &tmp,
+-				m_exp_index_transform_pow2p_type);
++  gimple_seq stmts = gen_pow2p (index, UNKNOWN_LOCATION, &tmp);
+   gsi = gsi_last_bb (cond_bb);
+   gsi_insert_seq_after (&gsi, stmts, GSI_LAST_NEW_STMT);
+   gcond *stmt_cond = gimple_build_cond (NE_EXPR, tmp, boolean_false_node,
+diff --git a/gcc/tree-switch-conversion.h b/gcc/tree-switch-conversion.h
+index 14610499e5fb..6468995eb316 100644
+--- a/gcc/tree-switch-conversion.h
++++ b/gcc/tree-switch-conversion.h
+@@ -920,11 +920,9 @@ public:
+   bool m_exp_index_transform_applied;
+ 
+   /* If switch conversion decided exponential index transform is viable, here
+-     will be stored the types to which index variable has to be converted
+-     before the logarithm and the "is power of 2" operations which are part of
+-     the transform.  */
++     will be stored the type to which index variable has to be converted
++     before the logarithm operation which is a part of the transform.  */
+   tree m_exp_index_transform_log2_type;
+-  tree m_exp_index_transform_pow2p_type;
+ };
+ 
+ void
+-- 
+2.46.2
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index a035c01..6c31450 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+13	29 September 2024
+
+	+ 71_all_PR116878-libcall.patch
+
 12	1 September 2024
 
 	- 32_all_PR116470-debug-bootstrap.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-09-30 14:05 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-09-30 14:05 UTC (permalink / raw
  To: gentoo-commits
commit:     4dffefc137f5ba6524cdb6eb598313646c5df6c8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 14:05:13 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 14:05:13 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=4dffefc1
15.0.0: drop 70_all_middle-end-check-explicitly-for-external-or-constant.patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...check-explicitly-for-external-or-constant.patch | 88 ----------------------
 15.0.0/gentoo/README.history                       |  5 ++
 2 files changed, 5 insertions(+), 88 deletions(-)
diff --git a/15.0.0/gentoo/70_all_middle-end-check-explicitly-for-external-or-constant.patch b/15.0.0/gentoo/70_all_middle-end-check-explicitly-for-external-or-constant.patch
deleted file mode 100644
index 7dcf89d..0000000
--- a/15.0.0/gentoo/70_all_middle-end-check-explicitly-for-external-or-constant.patch
+++ /dev/null
@@ -1,88 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/patch-18806-tamar@arm.com/T/#u
-https://gcc.gnu.org/PR116817
-
-From 9a5d1eb943dcaf26551b534eb62cbf1dd8443335 Mon Sep 17 00:00:00 2001
-Message-ID: <9a5d1eb943dcaf26551b534eb62cbf1dd8443335.1727104663.git.sam@gentoo.org>
-From: Tamar Christina <tamar.christina@arm.com>
-Date: Mon, 23 Sep 2024 15:29:52 +0100
-Subject: [PATCH] middle-end: check explicitly for external or constants when
- checking for loop invariant [PR116817]
-
-Hi All,
-
-The previous check if a value was external was checking
-!vect_get_internal_def (vinfo, var) but this of course isn't completely right
-as they could reductions etc.
-
-This changes the check to just explicitly look at externals and constants.
-Note that reductions remain unhandled here, but we don't support codegen of
-boolean reductions today anyway.
-
-So at the time we do then this would have the be handled as well in lowering.
-
-Bootstrapped Regtested on aarch64-none-linux-gnu and no issues.
-
-Ok for master?
-
-Thanks,
-Tamar
-
-gcc/ChangeLog:
-
-	PR tree-optimization/116817
-	* tree-vect-patterns.cc (vect_recog_bool_pattern): Check for const or
-	externals.
-
-gcc/testsuite/ChangeLog:
-
-PR tree-optimization/116817
-	* g++.dg/vect/pr116817.cc: New test.
----
- gcc/testsuite/g++.dg/vect/pr116817.cc | 16 ++++++++++++++++
- gcc/tree-vect-patterns.cc             |  5 ++++-
- 2 files changed, 20 insertions(+), 1 deletion(-)
- create mode 100644 gcc/testsuite/g++.dg/vect/pr116817.cc
-
-diff --git a/gcc/testsuite/g++.dg/vect/pr116817.cc b/gcc/testsuite/g++.dg/vect/pr116817.cc
-new file mode 100644
-index 00000000000..7e28982fb13
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/vect/pr116817.cc
-@@ -0,0 +1,16 @@
-+/* { dg-do compile } */
-+/* { dg-additional-options "-O3" } */
-+
-+int main_ulData0;
-+unsigned *main_pSrcBuffer;
-+int main(void) {
-+  int iSrc = 0;
-+  bool bData0;
-+  for (; iSrc < 4; iSrc++) {
-+    if (bData0)
-+      main_pSrcBuffer[iSrc] = main_ulData0;
-+    else
-+      main_pSrcBuffer[iSrc] = 0;
-+    bData0 = !bData0;
-+  }
-+}
-diff --git a/gcc/tree-vect-patterns.cc b/gcc/tree-vect-patterns.cc
-index e7e877dd2adb55262822f1660f8d92b42d44e6d0..f0298b2ab97a1e7dd0d943340e1389c3c0fa796e 100644
---- a/gcc/tree-vect-patterns.cc
-+++ b/gcc/tree-vect-patterns.cc
-@@ -6062,12 +6062,15 @@ vect_recog_bool_pattern (vec_info *vinfo,
-       if (get_vectype_for_scalar_type (vinfo, type) == NULL_TREE)
- 	return NULL;
- 
-+      stmt_vec_info var_def_info = vinfo->lookup_def (var);
-       if (check_bool_pattern (var, vinfo, bool_stmts))
- 	var = adjust_bool_stmts (vinfo, bool_stmts, type, stmt_vinfo);
-       else if (integer_type_for_mask (var, vinfo))
- 	return NULL;
-       else if (TREE_CODE (TREE_TYPE (var)) == BOOLEAN_TYPE
--	       && !vect_get_internal_def (vinfo, var))
-+	       && (!var_def_info
-+		   || STMT_VINFO_DEF_TYPE (var_def_info) == vect_external_def
-+		   || STMT_VINFO_DEF_TYPE (var_def_info) == vect_constant_def))
- 	{
- 	  /* If the condition is already a boolean then manually convert it to a
- 	     mask of the given integer type but don't set a vectype.  */
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 6c31450..819d192 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,10 @@
+14	????
+
+	- 70_all_middle-end-check-explicitly-for-external-or-constant.patch
+
 13	29 September 2024
 
+	+ 70_all_middle-end-check-explicitly-for-external-or-constant.patch
 	+ 71_all_PR116878-libcall.patch
 
 12	1 September 2024
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-02 19:45 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-02 19:45 UTC (permalink / raw
  To: gentoo-commits
commit:     6566f31fc01e405d7cad5739140fb61e98b0dd82
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Oct  2 19:44:53 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Oct  2 19:44:53 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=6566f31f
15.0.0: drop 71_all_PR116878-libcall.patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/71_all_PR116878-libcall.patch | 215 ----------------------------
 15.0.0/gentoo/README.history                |   1 +
 2 files changed, 1 insertion(+), 215 deletions(-)
diff --git a/15.0.0/gentoo/71_all_PR116878-libcall.patch b/15.0.0/gentoo/71_all_PR116878-libcall.patch
deleted file mode 100644
index 781196d..0000000
--- a/15.0.0/gentoo/71_all_PR116878-libcall.patch
+++ /dev/null
@@ -1,215 +0,0 @@
-https://gcc.gnu.org/PR116878
-https://gcc.gnu.org/PR116616
-
-From b9883d33e6338b1a44247b3f8772a5e5d2757593 Mon Sep 17 00:00:00 2001
-Message-ID: <b9883d33e6338b1a44247b3f8772a5e5d2757593.1727650422.git.sam@gentoo.org>
-From: Filip Kastl <fkastl@suse.cz>
-Date: Tue, 10 Sep 2024 19:22:27 +0200
-Subject: [PATCH] gimple ssa: Don't use __builtin_popcount in switch exp
- transform
-
-Switch exponential transformation in the switch conversion pass
-currently generates
-
-tmp1 = __builtin_popcount (var);
-tmp2 = tmp1 == 1;
-
-when inserting code to determine if var is power of two.  If the target
-doesn't support expanding the builtin as special instructions switch
-conversion relies on this whole pattern being expanded as bitmagic.
-However, it is possible that other GIMPLE optimizations move the two
-statements of the pattern apart.  In that case the builtin becomes a
-libgcc call in the final binary.  The call is slow and in case of
-freestanding programs can result in linking error (this bug was
-originally found while compiling Linux kernel).
-
-This patch modifies switch conversion to insert the bitmagic
-(var ^ (var - 1)) > (var - 1) instead of the builtin.
-
-gcc/ChangeLog:
-
-	PR tree-optimization/116616
-	* tree-switch-conversion.cc (can_pow2p): Remove this function.
-	(gen_pow2p): Generate bitmagic instead of a builtin.  Remove the
-	TYPE parameter.
-	(switch_conversion::is_exp_index_transform_viable): Don't call
-	can_pow2p.
-	(switch_conversion::exp_index_transform): Call gen_pow2p without
-	the TYPE parameter.
-	* tree-switch-conversion.h: Remove
-	m_exp_index_transform_pow2p_type.
-
-gcc/testsuite/ChangeLog:
-
-	PR tree-optimization/116616
-	* gcc.target/i386/switch-exp-transform-1.c: Don't test for
-	presence of the POPCOUNT internal fn call.
-
-Signed-off-by: Filip Kastl <fkastl@suse.cz>
----
- .../gcc.target/i386/switch-exp-transform-1.c  |  7 +-
- gcc/tree-switch-conversion.cc                 | 84 +++++--------------
- gcc/tree-switch-conversion.h                  |  6 +-
- 3 files changed, 23 insertions(+), 74 deletions(-)
-
-diff --git a/gcc/testsuite/gcc.target/i386/switch-exp-transform-1.c b/gcc/testsuite/gcc.target/i386/switch-exp-transform-1.c
-index a8c9e03e515f..4832f5b52c33 100644
---- a/gcc/testsuite/gcc.target/i386/switch-exp-transform-1.c
-+++ b/gcc/testsuite/gcc.target/i386/switch-exp-transform-1.c
-@@ -1,10 +1,8 @@
- /* { dg-do compile } */
--/* { dg-options "-O2 -fdump-tree-switchconv -fdump-tree-widening_mul -mpopcnt -mbmi" } */
-+/* { dg-options "-O2 -fdump-tree-switchconv -mbmi" } */
- 
- /* Checks that exponential index transform enables switch conversion to convert
--   this switch into an array lookup.  Also checks that the "index variable is a
--   power of two" check has been generated and that it has been later expanded
--   into an internal function.  */
-+   this switch into an array lookup.  */
- 
- int foo(unsigned bar)
- {
-@@ -30,4 +28,3 @@ int foo(unsigned bar)
- }
- 
- /* { dg-final { scan-tree-dump "CSWTCH" "switchconv" } } */
--/* { dg-final { scan-tree-dump "POPCOUNT" "widening_mul" } } */
-diff --git a/gcc/tree-switch-conversion.cc b/gcc/tree-switch-conversion.cc
-index c1332a260943..00426d400006 100644
---- a/gcc/tree-switch-conversion.cc
-+++ b/gcc/tree-switch-conversion.cc
-@@ -133,75 +133,33 @@ gen_log2 (tree op, location_t loc, tree *result, tree type)
-   return stmts;
- }
- 
--/* Is it possible to efficiently check that a value of TYPE is a power of 2?
--
--   If yes, returns TYPE.  If no, returns NULL_TREE.  May also return another
--   type.  This indicates that logarithm of the variable can be computed but
--   only after it is converted to this type.
--
--   Also see gen_pow2p.  */
--
--static tree
--can_pow2p (tree type)
--{
--  /* __builtin_popcount supports the unsigned type or its long and long long
--     variants.  Choose the smallest out of those that can still fit TYPE.  */
--  int prec = TYPE_PRECISION (type);
--  int i_prec = TYPE_PRECISION (unsigned_type_node);
--  int li_prec = TYPE_PRECISION (long_unsigned_type_node);
--  int lli_prec = TYPE_PRECISION (long_long_unsigned_type_node);
--
--  if (prec <= i_prec)
--    return unsigned_type_node;
--  else if (prec <= li_prec)
--    return long_unsigned_type_node;
--  else if (prec <= lli_prec)
--    return long_long_unsigned_type_node;
--  else
--    return NULL_TREE;
--}
--
--/* Build a sequence of gimple statements checking that OP is a power of 2.  Use
--   special optabs if target supports them.  Return the result as a
--   boolean_type_node ssa name through RESULT.  Assumes that OP's value will
--   be non-negative.  The generated check may give arbitrary answer for negative
--   values.
--
--   Before computing the check, OP may have to be converted to another type.
--   This should be specified in TYPE.  Use can_pow2p to decide what this type
--   should be.
--
--   Should only be used if can_pow2p returns true for type of OP.  */
-+/* Build a sequence of gimple statements checking that OP is a power of 2.
-+   Return the result as a boolean_type_node ssa name through RESULT.  Assumes
-+   that OP's value will be non-negative.  The generated check may give
-+   arbitrary answer for negative values.  */
- 
- static gimple_seq
--gen_pow2p (tree op, location_t loc, tree *result, tree type)
-+gen_pow2p (tree op, location_t loc, tree *result)
- {
-   gimple_seq stmts = NULL;
-   gimple_stmt_iterator gsi = gsi_last (stmts);
- 
--  built_in_function fn;
--  if (type == unsigned_type_node)
--    fn = BUILT_IN_POPCOUNT;
--  else if (type == long_unsigned_type_node)
--    fn = BUILT_IN_POPCOUNTL;
--  else
--    {
--      fn = BUILT_IN_POPCOUNTLL;
--      gcc_checking_assert (type == long_long_unsigned_type_node);
--    }
-+  tree type = TREE_TYPE (op);
-+  tree utype = unsigned_type_for (type);
- 
--  tree orig_type = TREE_TYPE (op);
-+  /* Build (op ^ (op - 1)) > (op - 1).  */
-   tree tmp1;
--  if (type != orig_type)
--    tmp1 = gimple_convert (&gsi, false, GSI_NEW_STMT, loc, type, op);
--  else
-+  if (types_compatible_p (type, utype))
-     tmp1 = op;
--  /* Build __builtin_popcount{l,ll} (op) == 1.  */
--  tree tmp2 = gimple_build (&gsi, false, GSI_NEW_STMT, loc,
--			    as_combined_fn (fn), integer_type_node, tmp1);
--  *result = gimple_build (&gsi, false, GSI_NEW_STMT, loc, EQ_EXPR,
--			  boolean_type_node, tmp2,
--			  build_one_cst (integer_type_node));
-+  else
-+    tmp1 = gimple_convert (&gsi, false, GSI_NEW_STMT, loc, utype, op);
-+  tree tmp2 = gimple_build (&gsi, false, GSI_NEW_STMT, loc, MINUS_EXPR, utype,
-+			    tmp1, build_one_cst (utype));
-+  tree tmp3 = gimple_build (&gsi, false, GSI_NEW_STMT, loc, BIT_XOR_EXPR,
-+			    utype, tmp1, tmp2);
-+  *result = gimple_build (&gsi, false, GSI_NEW_STMT, loc, GT_EXPR,
-+			  boolean_type_node, tmp3, tmp2);
-+
-   return stmts;
- }
- 
-@@ -371,9 +329,6 @@ switch_conversion::is_exp_index_transform_viable (gswitch *swtch)
-   m_exp_index_transform_log2_type = can_log2 (index_type, opt_type);
-   if (!m_exp_index_transform_log2_type)
-     return false;
--  m_exp_index_transform_pow2p_type = can_pow2p (index_type);
--  if (!m_exp_index_transform_pow2p_type)
--    return false;
- 
-   /* Check that each case label corresponds only to one value
-      (no case 1..3).  */
-@@ -467,8 +422,7 @@ switch_conversion::exp_index_transform (gswitch *swtch)
-   new_edge2->probability = profile_probability::even ();
- 
-   tree tmp;
--  gimple_seq stmts = gen_pow2p (index, UNKNOWN_LOCATION, &tmp,
--				m_exp_index_transform_pow2p_type);
-+  gimple_seq stmts = gen_pow2p (index, UNKNOWN_LOCATION, &tmp);
-   gsi = gsi_last_bb (cond_bb);
-   gsi_insert_seq_after (&gsi, stmts, GSI_LAST_NEW_STMT);
-   gcond *stmt_cond = gimple_build_cond (NE_EXPR, tmp, boolean_false_node,
-diff --git a/gcc/tree-switch-conversion.h b/gcc/tree-switch-conversion.h
-index 14610499e5fb..6468995eb316 100644
---- a/gcc/tree-switch-conversion.h
-+++ b/gcc/tree-switch-conversion.h
-@@ -920,11 +920,9 @@ public:
-   bool m_exp_index_transform_applied;
- 
-   /* If switch conversion decided exponential index transform is viable, here
--     will be stored the types to which index variable has to be converted
--     before the logarithm and the "is power of 2" operations which are part of
--     the transform.  */
-+     will be stored the type to which index variable has to be converted
-+     before the logarithm operation which is a part of the transform.  */
-   tree m_exp_index_transform_log2_type;
--  tree m_exp_index_transform_pow2p_type;
- };
- 
- void
--- 
-2.46.2
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 819d192..d966e4c 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 14	????
 
 	- 70_all_middle-end-check-explicitly-for-external-or-constant.patch
+	- 71_all_PR116878-libcall.patch
 
 13	29 September 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-04  9:28 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-04  9:28 UTC (permalink / raw
  To: gentoo-commits
commit:     f44cf391c1dbacd2651298e2fb366905a5fe0a06
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Oct  4 09:27:50 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Oct  4 09:27:50 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=f44cf391
15.0.0: add two C++ patches
+ 71_all_c-Allow-references-to-internal-linkage-vars-in-C-11-.patch
+ 72_all_c-Return-the-underlying-decl-rather-than-the-USING_D.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...erences-to-internal-linkage-vars-in-C-11-.patch | 96 ++++++++++++++++++++++
 ...e-underlying-decl-rather-than-the-USING_D.patch | 76 +++++++++++++++++
 15.0.0/gentoo/README.history                       |  4 +-
 3 files changed, 175 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/71_all_c-Allow-references-to-internal-linkage-vars-in-C-11-.patch b/15.0.0/gentoo/71_all_c-Allow-references-to-internal-linkage-vars-in-C-11-.patch
new file mode 100644
index 0000000..4e2f1f4
--- /dev/null
+++ b/15.0.0/gentoo/71_all_c-Allow-references-to-internal-linkage-vars-in-C-11-.patch
@@ -0,0 +1,96 @@
+From 923bd335a44b1b556d705a7f1d36a2e9c06d9c5c Mon Sep 17 00:00:00 2001
+Message-ID: <923bd335a44b1b556d705a7f1d36a2e9c06d9c5c.1728034006.git.sam@gentoo.org>
+From: Nathaniel Shead <nathanieloshead@gmail.com>
+Date: Fri, 4 Oct 2024 12:41:49 +1000
+Subject: [PATCH 1/2] c++: Allow references to internal-linkage vars in C++11
+ [PR113266]
+
+[temp.arg.nontype] changed in C++11 to allow naming internal-linkage
+variables and functions.  We currently already handle internal-linkage
+functions, but variables were missed; this patch updates this.
+
+	PR c++/113266
+	PR c++/116911
+
+gcc/cp/ChangeLog:
+
+	* parser.cc (cp_parser_template_argument): Allow
+	internal-linkage variables since C++11.
+
+gcc/testsuite/ChangeLog:
+
+	* g++.dg/cpp0x/nontype6.C: New test.
+
+Signed-off-by: Nathaniel Shead <nathanieloshead@gmail.com>
+---
+ gcc/cp/parser.cc                      | 17 ++++++++++++-----
+ gcc/testsuite/g++.dg/cpp0x/nontype6.C | 19 +++++++++++++++++++
+ 2 files changed, 31 insertions(+), 5 deletions(-)
+ create mode 100644 gcc/testsuite/g++.dg/cpp0x/nontype6.C
+
+diff --git a/gcc/cp/parser.cc b/gcc/cp/parser.cc
+index 08f9c89f1f0..e758ddeb1d5 100644
+--- a/gcc/cp/parser.cc
++++ b/gcc/cp/parser.cc
+@@ -19864,9 +19864,11 @@ cp_parser_template_argument (cp_parser* parser)
+ 
+      -- the name of a non-type template-parameter; or
+ 
+-     -- the name of an object or function with external linkage...
++     -- the name of an object or function with external (or internal,
++	since C++11) linkage...
+ 
+-     -- the address of an object or function with external linkage...
++     -- the address of an object or function with external (or internal,
++	since C++11) linkage...
+ 
+      -- a pointer to member...  */
+   /* Look for a non-type template parameter.  */
+@@ -19929,11 +19931,16 @@ cp_parser_template_argument (cp_parser* parser)
+ 	    probe = TREE_OPERAND (probe, 1);
+ 	  if (VAR_P (probe))
+ 	    {
+-	      /* A variable without external linkage might still be a
++	      /* A variable without valid linkage might still be a
+ 		 valid constant-expression, so no error is issued here
+ 		 if the external-linkage check fails.  */
+-	      if (!address_p && !DECL_EXTERNAL_LINKAGE_P (probe))
+-		cp_parser_simulate_error (parser);
++	      if (!address_p && cxx_dialect < cxx17)
++		{
++		  linkage_kind linkage = decl_linkage (probe);
++		  if (linkage != lk_external
++		      && (cxx_dialect < cxx11 || linkage != lk_internal))
++		    cp_parser_simulate_error (parser);
++		}
+ 	    }
+ 	  else if (is_overloaded_fn (argument))
+ 	    /* All overloaded functions are allowed; if the external
+diff --git a/gcc/testsuite/g++.dg/cpp0x/nontype6.C b/gcc/testsuite/g++.dg/cpp0x/nontype6.C
+new file mode 100644
+index 00000000000..5543d1e8b6d
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/cpp0x/nontype6.C
+@@ -0,0 +1,19 @@
++// PR c++/113266, PR c++/116911
++// { dg-do compile }
++
++template <int &> struct a {};
++static int guard1;
++a<guard1> b;  // { dg-error "constant-expression|invalid" "" { target c++98_only } }
++
++namespace {
++  int guard2;
++}
++a<guard2> c;  // OK in C++98 because guard2 has external linkage
++              // OK since C++11 because we can refer to an internal linkage decl
++
++void nolinkage() {
++  static int guard3;
++  a<guard3> d;  // { dg-error "constant-expression|invalid" "" { target c++98_only } }
++  // { dg-error "constant expression|no linkage" "" { target { c++11 && c++14_down } } .-1 }
++  // OK since C++17 since we can now refer to no-linkage decls
++}
+-- 
+2.46.2
+
diff --git a/15.0.0/gentoo/72_all_c-Return-the-underlying-decl-rather-than-the-USING_D.patch b/15.0.0/gentoo/72_all_c-Return-the-underlying-decl-rather-than-the-USING_D.patch
new file mode 100644
index 0000000..ab12bf6
--- /dev/null
+++ b/15.0.0/gentoo/72_all_c-Return-the-underlying-decl-rather-than-the-USING_D.patch
@@ -0,0 +1,76 @@
+From ba7c4e109fc589603911630deb2f19eba88bdbe8 Mon Sep 17 00:00:00 2001
+Message-ID: <ba7c4e109fc589603911630deb2f19eba88bdbe8.1728034006.git.sam@gentoo.org>
+In-Reply-To: <923bd335a44b1b556d705a7f1d36a2e9c06d9c5c.1728034006.git.sam@gentoo.org>
+References: <923bd335a44b1b556d705a7f1d36a2e9c06d9c5c.1728034006.git.sam@gentoo.org>
+From: Nathaniel Shead <nathanieloshead@gmail.com>
+Date: Fri, 4 Oct 2024 10:52:02 +1000
+Subject: [PATCH 2/2] c++: Return the underlying decl rather than the
+ USING_DECL from update_binding [PR116913]
+
+Users of pushdecl assume that the returned decl will be a possibly
+updated decl matching the one that was passed in.  My r15-3910 change
+broke this since in some cases we would now return USING_DECLs; this
+patch fixes the situation.
+
+	PR c++/116913
+
+gcc/cp/ChangeLog:
+
+	* name-lookup.cc (update_binding): Return the strip_using'd old
+	decl rather than the binding.
+
+gcc/testsuite/ChangeLog:
+
+	* g++.dg/lookup/using70.C: New test.
+
+Signed-off-by: Nathaniel Shead <nathanieloshead@gmail.com>
+---
+ gcc/cp/name-lookup.cc                 |  4 ++--
+ gcc/testsuite/g++.dg/lookup/using70.C | 13 +++++++++++++
+ 2 files changed, 15 insertions(+), 2 deletions(-)
+ create mode 100644 gcc/testsuite/g++.dg/lookup/using70.C
+
+diff --git a/gcc/cp/name-lookup.cc b/gcc/cp/name-lookup.cc
+index 4754ef5a522..609bd6e8c9b 100644
+--- a/gcc/cp/name-lookup.cc
++++ b/gcc/cp/name-lookup.cc
+@@ -3101,7 +3101,7 @@ update_binding (cp_binding_level *level, cxx_binding *binding, tree *slot,
+ 	{
+ 	  if (same_type_p (TREE_TYPE (old), TREE_TYPE (decl)))
+ 	    /* Two type decls to the same type.  Do nothing.  */
+-	    return old_bval;
++	    return old;
+ 	  else
+ 	    goto conflict;
+ 	}
+@@ -3114,7 +3114,7 @@ update_binding (cp_binding_level *level, cxx_binding *binding, tree *slot,
+ 
+ 	  /* The new one must be an alias at this point.  */
+ 	  gcc_assert (DECL_NAMESPACE_ALIAS (decl));
+-	  return old_bval;
++	  return old;
+ 	}
+       else if (TREE_CODE (old) == VAR_DECL)
+ 	{
+diff --git a/gcc/testsuite/g++.dg/lookup/using70.C b/gcc/testsuite/g++.dg/lookup/using70.C
+new file mode 100644
+index 00000000000..14838eea7ec
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/lookup/using70.C
+@@ -0,0 +1,13 @@
++// PR c++/116913
++// { dg-do compile { target c++11 } }
++
++namespace ns {
++  struct c {};
++  using d = int;
++}
++
++using ns::c;
++using ns::d;
++
++using c = ns::c;
++using d = ns::d;
+-- 
+2.46.2
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index d966e4c..2d85dc2 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,7 +1,9 @@
-14	????
+14	4 October 2024
 
 	- 70_all_middle-end-check-explicitly-for-external-or-constant.patch
 	- 71_all_PR116878-libcall.patch
+	+ 71_all_c-Allow-references-to-internal-linkage-vars-in-C-11-.patch
+	+ 72_all_c-Return-the-underlying-decl-rather-than-the-USING_D.patch
 
 13	29 September 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-04 10:37 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-04 10:37 UTC (permalink / raw
  To: gentoo-commits
commit:     fd69f7a88e4fa1dd773750c0ce7a31c20f452ce2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Oct  4 10:36:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Oct  4 10:36:57 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=fd69f7a8
15.0.0: drop patches merged upstream
- 71_all_c-Allow-references-to-internal-linkage-vars-in-C-11-.patch
- 72_all_c-Return-the-underlying-decl-rather-than-the-USING_D.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...erences-to-internal-linkage-vars-in-C-11-.patch | 96 ----------------------
 ...e-underlying-decl-rather-than-the-USING_D.patch | 76 -----------------
 15.0.0/gentoo/README.history                       |  5 ++
 3 files changed, 5 insertions(+), 172 deletions(-)
diff --git a/15.0.0/gentoo/71_all_c-Allow-references-to-internal-linkage-vars-in-C-11-.patch b/15.0.0/gentoo/71_all_c-Allow-references-to-internal-linkage-vars-in-C-11-.patch
deleted file mode 100644
index 4e2f1f4..0000000
--- a/15.0.0/gentoo/71_all_c-Allow-references-to-internal-linkage-vars-in-C-11-.patch
+++ /dev/null
@@ -1,96 +0,0 @@
-From 923bd335a44b1b556d705a7f1d36a2e9c06d9c5c Mon Sep 17 00:00:00 2001
-Message-ID: <923bd335a44b1b556d705a7f1d36a2e9c06d9c5c.1728034006.git.sam@gentoo.org>
-From: Nathaniel Shead <nathanieloshead@gmail.com>
-Date: Fri, 4 Oct 2024 12:41:49 +1000
-Subject: [PATCH 1/2] c++: Allow references to internal-linkage vars in C++11
- [PR113266]
-
-[temp.arg.nontype] changed in C++11 to allow naming internal-linkage
-variables and functions.  We currently already handle internal-linkage
-functions, but variables were missed; this patch updates this.
-
-	PR c++/113266
-	PR c++/116911
-
-gcc/cp/ChangeLog:
-
-	* parser.cc (cp_parser_template_argument): Allow
-	internal-linkage variables since C++11.
-
-gcc/testsuite/ChangeLog:
-
-	* g++.dg/cpp0x/nontype6.C: New test.
-
-Signed-off-by: Nathaniel Shead <nathanieloshead@gmail.com>
----
- gcc/cp/parser.cc                      | 17 ++++++++++++-----
- gcc/testsuite/g++.dg/cpp0x/nontype6.C | 19 +++++++++++++++++++
- 2 files changed, 31 insertions(+), 5 deletions(-)
- create mode 100644 gcc/testsuite/g++.dg/cpp0x/nontype6.C
-
-diff --git a/gcc/cp/parser.cc b/gcc/cp/parser.cc
-index 08f9c89f1f0..e758ddeb1d5 100644
---- a/gcc/cp/parser.cc
-+++ b/gcc/cp/parser.cc
-@@ -19864,9 +19864,11 @@ cp_parser_template_argument (cp_parser* parser)
- 
-      -- the name of a non-type template-parameter; or
- 
--     -- the name of an object or function with external linkage...
-+     -- the name of an object or function with external (or internal,
-+	since C++11) linkage...
- 
--     -- the address of an object or function with external linkage...
-+     -- the address of an object or function with external (or internal,
-+	since C++11) linkage...
- 
-      -- a pointer to member...  */
-   /* Look for a non-type template parameter.  */
-@@ -19929,11 +19931,16 @@ cp_parser_template_argument (cp_parser* parser)
- 	    probe = TREE_OPERAND (probe, 1);
- 	  if (VAR_P (probe))
- 	    {
--	      /* A variable without external linkage might still be a
-+	      /* A variable without valid linkage might still be a
- 		 valid constant-expression, so no error is issued here
- 		 if the external-linkage check fails.  */
--	      if (!address_p && !DECL_EXTERNAL_LINKAGE_P (probe))
--		cp_parser_simulate_error (parser);
-+	      if (!address_p && cxx_dialect < cxx17)
-+		{
-+		  linkage_kind linkage = decl_linkage (probe);
-+		  if (linkage != lk_external
-+		      && (cxx_dialect < cxx11 || linkage != lk_internal))
-+		    cp_parser_simulate_error (parser);
-+		}
- 	    }
- 	  else if (is_overloaded_fn (argument))
- 	    /* All overloaded functions are allowed; if the external
-diff --git a/gcc/testsuite/g++.dg/cpp0x/nontype6.C b/gcc/testsuite/g++.dg/cpp0x/nontype6.C
-new file mode 100644
-index 00000000000..5543d1e8b6d
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/cpp0x/nontype6.C
-@@ -0,0 +1,19 @@
-+// PR c++/113266, PR c++/116911
-+// { dg-do compile }
-+
-+template <int &> struct a {};
-+static int guard1;
-+a<guard1> b;  // { dg-error "constant-expression|invalid" "" { target c++98_only } }
-+
-+namespace {
-+  int guard2;
-+}
-+a<guard2> c;  // OK in C++98 because guard2 has external linkage
-+              // OK since C++11 because we can refer to an internal linkage decl
-+
-+void nolinkage() {
-+  static int guard3;
-+  a<guard3> d;  // { dg-error "constant-expression|invalid" "" { target c++98_only } }
-+  // { dg-error "constant expression|no linkage" "" { target { c++11 && c++14_down } } .-1 }
-+  // OK since C++17 since we can now refer to no-linkage decls
-+}
--- 
-2.46.2
-
diff --git a/15.0.0/gentoo/72_all_c-Return-the-underlying-decl-rather-than-the-USING_D.patch b/15.0.0/gentoo/72_all_c-Return-the-underlying-decl-rather-than-the-USING_D.patch
deleted file mode 100644
index ab12bf6..0000000
--- a/15.0.0/gentoo/72_all_c-Return-the-underlying-decl-rather-than-the-USING_D.patch
+++ /dev/null
@@ -1,76 +0,0 @@
-From ba7c4e109fc589603911630deb2f19eba88bdbe8 Mon Sep 17 00:00:00 2001
-Message-ID: <ba7c4e109fc589603911630deb2f19eba88bdbe8.1728034006.git.sam@gentoo.org>
-In-Reply-To: <923bd335a44b1b556d705a7f1d36a2e9c06d9c5c.1728034006.git.sam@gentoo.org>
-References: <923bd335a44b1b556d705a7f1d36a2e9c06d9c5c.1728034006.git.sam@gentoo.org>
-From: Nathaniel Shead <nathanieloshead@gmail.com>
-Date: Fri, 4 Oct 2024 10:52:02 +1000
-Subject: [PATCH 2/2] c++: Return the underlying decl rather than the
- USING_DECL from update_binding [PR116913]
-
-Users of pushdecl assume that the returned decl will be a possibly
-updated decl matching the one that was passed in.  My r15-3910 change
-broke this since in some cases we would now return USING_DECLs; this
-patch fixes the situation.
-
-	PR c++/116913
-
-gcc/cp/ChangeLog:
-
-	* name-lookup.cc (update_binding): Return the strip_using'd old
-	decl rather than the binding.
-
-gcc/testsuite/ChangeLog:
-
-	* g++.dg/lookup/using70.C: New test.
-
-Signed-off-by: Nathaniel Shead <nathanieloshead@gmail.com>
----
- gcc/cp/name-lookup.cc                 |  4 ++--
- gcc/testsuite/g++.dg/lookup/using70.C | 13 +++++++++++++
- 2 files changed, 15 insertions(+), 2 deletions(-)
- create mode 100644 gcc/testsuite/g++.dg/lookup/using70.C
-
-diff --git a/gcc/cp/name-lookup.cc b/gcc/cp/name-lookup.cc
-index 4754ef5a522..609bd6e8c9b 100644
---- a/gcc/cp/name-lookup.cc
-+++ b/gcc/cp/name-lookup.cc
-@@ -3101,7 +3101,7 @@ update_binding (cp_binding_level *level, cxx_binding *binding, tree *slot,
- 	{
- 	  if (same_type_p (TREE_TYPE (old), TREE_TYPE (decl)))
- 	    /* Two type decls to the same type.  Do nothing.  */
--	    return old_bval;
-+	    return old;
- 	  else
- 	    goto conflict;
- 	}
-@@ -3114,7 +3114,7 @@ update_binding (cp_binding_level *level, cxx_binding *binding, tree *slot,
- 
- 	  /* The new one must be an alias at this point.  */
- 	  gcc_assert (DECL_NAMESPACE_ALIAS (decl));
--	  return old_bval;
-+	  return old;
- 	}
-       else if (TREE_CODE (old) == VAR_DECL)
- 	{
-diff --git a/gcc/testsuite/g++.dg/lookup/using70.C b/gcc/testsuite/g++.dg/lookup/using70.C
-new file mode 100644
-index 00000000000..14838eea7ec
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/lookup/using70.C
-@@ -0,0 +1,13 @@
-+// PR c++/116913
-+// { dg-do compile { target c++11 } }
-+
-+namespace ns {
-+  struct c {};
-+  using d = int;
-+}
-+
-+using ns::c;
-+using ns::d;
-+
-+using c = ns::c;
-+using d = ns::d;
--- 
-2.46.2
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 2d85dc2..f58b501 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,8 @@
+15	????
+
+	- 71_all_c-Allow-references-to-internal-linkage-vars-in-C-11-.patch
+	- 72_all_c-Return-the-underlying-decl-rather-than-the-USING_D.patch
+
 14	4 October 2024
 
 	- 70_all_middle-end-check-explicitly-for-external-or-constant.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-07  2:45 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-07  2:45 UTC (permalink / raw
  To: gentoo-commits
commit:     9a259e1746b11f94c3ccdeacb33bcc9ccfeb3f5f
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Oct  7 02:45:18 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Oct  7 02:45:18 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=9a259e17
15.0.0: cut patchset 15
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index f58b501..a6954a6 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-15	????
+15	7 October 2024
 
 	- 71_all_c-Allow-references-to-internal-linkage-vars-in-C-11-.patch
 	- 72_all_c-Return-the-underlying-decl-rather-than-the-USING_D.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-13 22:48 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-13 22:48 UTC (permalink / raw
  To: gentoo-commits
commit:     b4a852b00ffc7c9436d15867d602c28837c97758
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 13 22:47:21 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Oct 13 22:47:21 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b4a852b0
15.0.0: add two coro patches
Bug: https://gcc.gnu.org/PR116506
Bug: https://gcc.gnu.org/PR116914
Closes: https://bugs.gentoo.org/941147
Closes: https://bugs.gentoo.org/941148
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/70_all_PR116506-coro.patch | 295 +++++++++++++++++++++++++++++++
 15.0.0/gentoo/71_all_PR116914-coro.patch |  51 ++++++
 15.0.0/gentoo/README.history             |   5 +
 3 files changed, 351 insertions(+)
diff --git a/15.0.0/gentoo/70_all_PR116506-coro.patch b/15.0.0/gentoo/70_all_PR116506-coro.patch
new file mode 100644
index 0000000..4e670fc
--- /dev/null
+++ b/15.0.0/gentoo/70_all_PR116506-coro.patch
@@ -0,0 +1,295 @@
+From 06475fcc5b72fdb9b24e7e39703942e1e3f2f0d5 Mon Sep 17 00:00:00 2001
+From: Iain Sandoe <iain@sandoe.co.uk>
+Date: Thu, 29 Aug 2024 11:18:24 +0100
+Subject: [PATCH] c++, coroutines: Fix awaiter var creation [PR116506].
+
+Awaiters always need to have a coroutine state frame copy since
+they persist across potential supensions.  It simplifies the later
+analysis considerably to assign these early which we do when
+building co_await expressions.
+
+The cleanups in r15-3146-g47dbd69b1, unfortunately elided some of
+processing used to cater for cases where the var created from an
+xvalue, or is a pointer/reference type.
+
+Corrected thus.
+
+	PR c++/116506
+	PR c++/116880
+
+gcc/cp/ChangeLog:
+
+	* coroutines.cc (build_co_await): Ensure that xvalues are
+	materialised.  Handle references/pointer values in awaiter
+	access expressions.
+
+gcc/testsuite/ChangeLog:
+
+	* g++.dg/coroutines/pr116506.C: New test.
+	* g++.dg/coroutines/pr116880.C: New test.
+
+Signed-off-by: Iain Sandoe <iain@sandoe.co.uk>
+---
+ gcc/cp/coroutines.cc                       | 82 +++++++++++++++++-----
+ gcc/testsuite/g++.dg/coroutines/pr116506.C | 53 ++++++++++++++
+ gcc/testsuite/g++.dg/coroutines/pr116880.C | 36 ++++++++++
+ 3 files changed, 154 insertions(+), 17 deletions(-)
+ create mode 100644 gcc/testsuite/g++.dg/coroutines/pr116506.C
+ create mode 100644 gcc/testsuite/g++.dg/coroutines/pr116880.C
+
+diff --git a/gcc/cp/coroutines.cc b/gcc/cp/coroutines.cc
+index 86a5ac8999a..ba6ee41a4e7 100644
+--- a/gcc/cp/coroutines.cc
++++ b/gcc/cp/coroutines.cc
+@@ -1071,6 +1071,30 @@ build_template_co_await_expr (location_t kw, tree type, tree expr, tree kind)
+   return aw_expr;
+ }
+ 
++/* For a component ref that is not a pointer type, decide if we can use
++   this directly.  */
++static bool
++usable_component_ref (tree comp_ref)
++{
++  if (TREE_CODE (comp_ref) != COMPONENT_REF
++      || TREE_SIDE_EFFECTS (comp_ref))
++    return false;
++
++  while (TREE_CODE (comp_ref) == COMPONENT_REF)
++    {
++      comp_ref = TREE_OPERAND (comp_ref, 0);
++      STRIP_NOPS (comp_ref);
++      /* x-> */
++      if (INDIRECT_REF_P (comp_ref))
++	return false;
++      /* operator-> */
++      if (TREE_CODE (comp_ref) == CALL_EXPR)
++	return false;
++      STRIP_NOPS (comp_ref);
++    }
++  gcc_checking_assert (VAR_P (comp_ref) || TREE_CODE (comp_ref) == PARM_DECL);
++  return true;
++}
+ 
+ /*  This performs [expr.await] bullet 3.3 and validates the interface obtained.
+     It is also used to build the initial and final suspend points.
+@@ -1133,13 +1157,12 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
+   if (o_type && !VOID_TYPE_P (o_type))
+     o_type = complete_type_or_else (o_type, o);
+ 
+-  if (!o_type)
++  if (!o_type || o_type == error_mark_node)
+     return error_mark_node;
+ 
+   if (TREE_CODE (o_type) != RECORD_TYPE)
+     {
+-      error_at (loc, "awaitable type %qT is not a structure",
+-		o_type);
++      error_at (loc, "awaitable type %qT is not a structure", o_type);
+       return error_mark_node;
+     }
+ 
+@@ -1165,20 +1188,47 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
+   if (!glvalue_p (o))
+     o = get_target_expr (o, tf_warning_or_error);
+ 
+-  tree e_proxy = o;
+-  if (glvalue_p (o))
++  /* We know that we need a coroutine state frame variable for the awaiter,
++     since it must persist across suspension; so where one is needed, build
++     it now.  */
++  tree e_proxy = STRIP_NOPS (o);
++  if (INDIRECT_REF_P (e_proxy))
++    e_proxy = TREE_OPERAND (e_proxy, 0);
++  o_type = TREE_TYPE (e_proxy);
++  bool is_ptr = TYPE_PTR_P (o_type);
++  if (!is_ptr
++      && (TREE_CODE (e_proxy) == PARM_DECL
++	  || usable_component_ref (e_proxy)
++	  || (VAR_P (e_proxy) && !is_local_temp (e_proxy))))
+     o = NULL_TREE; /* Use the existing entity.  */
+-  else /* We need to materialise it.  */
++  else /* We need a non-temp var.  */
+     {
+-      e_proxy = get_awaitable_var (suspend_kind, o_type);
+-      o = cp_build_init_expr (loc, e_proxy, o);
+-      e_proxy = convert_from_reference (e_proxy);
++      tree p_type = o_type;
++      tree o_a = o;
++      if (lvalue_p (o) && !TREE_SIDE_EFFECTS (o))
++	{
++	  if (is_ptr)
++	    p_type = TREE_TYPE (p_type);
++	  p_type = cp_build_reference_type (p_type, false);
++	  o_a = build_address (o);
++	}
++      if (INDIRECT_REF_P (o_a))
++	o_a = TREE_OPERAND (o_a, 0);
++      e_proxy = get_awaitable_var (suspend_kind, p_type);
++      o = cp_build_init_expr (loc, e_proxy, o_a);
+     }
+ 
++  /* Build an expression for the object that will be used to call the awaitable
++     methods.  */
++  tree e_object = convert_from_reference (e_proxy);
++  if (TYPE_PTR_P (TREE_TYPE (e_object)))
++    e_object = cp_build_indirect_ref (input_location, e_object, RO_UNARY_STAR,
++				      tf_warning_or_error);
++
+   /* I suppose we could check that this is contextually convertible to bool.  */
+   tree awrd_func = NULL_TREE;
+   tree awrd_call
+-    = build_new_method_call (e_proxy, awrd_meth, NULL, NULL_TREE, LOOKUP_NORMAL,
++    = build_new_method_call (e_object, awrd_meth, NULL, NULL_TREE, LOOKUP_NORMAL,
+ 			     &awrd_func, tf_warning_or_error);
+ 
+   if (!awrd_func || !awrd_call || awrd_call == error_mark_node)
+@@ -1192,7 +1242,7 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
+   tree h_proxy = get_coroutine_self_handle_proxy (current_function_decl);
+   vec<tree, va_gc> *args = make_tree_vector_single (h_proxy);
+   tree awsp_call
+-    = build_new_method_call (e_proxy, awsp_meth, &args, NULL_TREE,
++    = build_new_method_call (e_object, awsp_meth, &args, NULL_TREE,
+ 			     LOOKUP_NORMAL, &awsp_func, tf_warning_or_error);
+ 
+   release_tree_vector (args);
+@@ -1224,7 +1274,7 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
+   /* Finally, the type of e.await_resume() is the co_await's type.  */
+   tree awrs_func = NULL_TREE;
+   tree awrs_call
+-    = build_new_method_call (e_proxy, awrs_meth, NULL, NULL_TREE, LOOKUP_NORMAL,
++    = build_new_method_call (e_object, awrs_meth, NULL, NULL_TREE, LOOKUP_NORMAL,
+ 			     &awrs_func, tf_warning_or_error);
+ 
+   if (!awrs_func || !awrs_call || awrs_call == error_mark_node)
+@@ -1238,7 +1288,7 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
+ 	return error_mark_node;
+       if (coro_diagnose_throwing_fn (awrs_func))
+ 	return error_mark_node;
+-      if (tree dummy = cxx_maybe_build_cleanup (e_proxy, tf_none))
++      if (tree dummy = cxx_maybe_build_cleanup (e_object, tf_none))
+ 	{
+ 	  if (CONVERT_EXPR_P (dummy))
+ 	    dummy = TREE_OPERAND (dummy, 0);
+@@ -1249,7 +1299,8 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
+     }
+ 
+   /* We now have three call expressions, in terms of the promise, handle and
+-     'e' proxies.  Save them in the await expression for later expansion.  */
++     'e' proxy expression.  Save them in the await expression for later
++     expansion.  */
+ 
+   tree awaiter_calls = make_tree_vec (3);
+   TREE_VEC_ELT (awaiter_calls, 0) = awrd_call; /* await_ready().  */
+@@ -1262,9 +1313,6 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
+     }
+   TREE_VEC_ELT (awaiter_calls, 2) = awrs_call; /* await_resume().  */
+ 
+-  if (REFERENCE_REF_P (e_proxy))
+-    e_proxy = TREE_OPERAND (e_proxy, 0);
+-
+   tree awrs_type = TREE_TYPE (TREE_TYPE (awrs_func));
+   tree suspend_kind_cst = build_int_cst (integer_type_node,
+ 					 (int) suspend_kind);
+diff --git a/gcc/testsuite/g++.dg/coroutines/pr116506.C b/gcc/testsuite/g++.dg/coroutines/pr116506.C
+new file mode 100644
+index 00000000000..57a6e360566
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/coroutines/pr116506.C
+@@ -0,0 +1,53 @@
++// { dg-do run }
++// { dg-additional-options "-fno-exceptions" }
++                                                       
++#include <coroutine>
++
++bool g_too_early = true;
++std::coroutine_handle<> g_handle;
++
++struct Awaiter {
++    Awaiter() {}
++    ~Awaiter() {
++        if (g_too_early) {
++            __builtin_abort ();
++        }
++    }
++
++    bool await_ready() { return false; }
++    void await_suspend(std::coroutine_handle<> handle) {
++        g_handle = handle;
++    }
++
++    void await_resume() {}
++};
++
++struct SuspendNever {
++    bool await_ready() noexcept { return true; }
++    void await_suspend(std::coroutine_handle<>) noexcept {}
++    void await_resume() noexcept {}
++};
++
++struct Coroutine {
++    struct promise_type {
++        Coroutine get_return_object() { return {}; }
++        SuspendNever initial_suspend() { return {}; }
++        SuspendNever final_suspend() noexcept { return {}; }
++        void return_void() {}
++        void unhandled_exception() {}
++
++        Awaiter&& await_transform(Awaiter&& u) {
++            return static_cast<Awaiter&&>(u);
++        }
++    };
++};
++
++Coroutine foo() {
++    co_await Awaiter{};
++}
++
++int main() {
++    foo();
++    g_too_early = false;
++    g_handle.destroy();
++}
+diff --git a/gcc/testsuite/g++.dg/coroutines/pr116880.C b/gcc/testsuite/g++.dg/coroutines/pr116880.C
+new file mode 100644
+index 00000000000..f0db6a26044
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/coroutines/pr116880.C
+@@ -0,0 +1,36 @@
++#include <coroutine>
++
++struct promise_type;
++using handle_type = std::coroutine_handle<promise_type>;
++
++struct Co {
++    handle_type handle;
++    using promise_type = ::promise_type;
++
++    explicit Co(handle_type handle) : handle(handle) {}
++
++    bool await_ready() { return false; }
++    std::coroutine_handle<> await_suspend(handle_type handle);
++    void await_resume() {}
++};
++
++struct Done {};
++
++struct promise_type {
++    Co get_return_object();
++
++    std::suspend_always initial_suspend() { return {}; };
++    std::suspend_always final_suspend() noexcept { return {}; };
++    void return_value(Done) {}
++    void return_value(Co&&);
++    void unhandled_exception() { throw; };
++    Co&& await_transform(Co&& co) { return static_cast<Co&&>(co); }
++};
++
++Co tryToRun();
++
++Co init()
++{
++    co_await tryToRun();
++    co_return Done{};
++}
+-- 
+2.39.2 (Apple Git-143)
diff --git a/15.0.0/gentoo/71_all_PR116914-coro.patch b/15.0.0/gentoo/71_all_PR116914-coro.patch
new file mode 100644
index 0000000..100d2bb
--- /dev/null
+++ b/15.0.0/gentoo/71_all_PR116914-coro.patch
@@ -0,0 +1,51 @@
+From 1035866a75b27bb2cac49bac1070877d95f7d3c0 Mon Sep 17 00:00:00 2001
+From: Iain Sandoe <iain@sandoe.co.uk>
+Date: Sun, 29 Sep 2024 10:04:39 +0100
+Subject: [PATCH] c++, coroutines: stmt expressions some progress
+
+---
+ gcc/cp/coroutines.cc | 22 ++++++++++++++++++++++
+ 1 file changed, 22 insertions(+)
+
+diff --git a/gcc/cp/coroutines.cc b/gcc/cp/coroutines.cc
+index af8798b04ba..94bfa6ac450 100644
+--- a/gcc/cp/coroutines.cc
++++ b/gcc/cp/coroutines.cc
+@@ -2131,6 +2131,14 @@ await_statement_expander (tree *stmt, int *do_subtree, void *d)
+     }
+   else if (EXPR_P (*stmt))
+     {
++      /* Look for ({}) at the top level - just recurse into these.  */
++      if (TREE_CODE (*stmt) == EXPR_STMT)
++	{
++	  tree inner = EXPR_STMT_EXPR (*stmt);
++	  if (TREE_CODE (inner) == STATEMENT_LIST
++	      || TREE_CODE (inner) == BIND_EXPR)
++	    return NULL_TREE; // process contents
++	}
+       process_one_statement (stmt, d);
+       *do_subtree = 0; /* Done subtrees.  */
+     }
+@@ -3860,6 +3868,20 @@ await_statement_walker (tree *stmt, int *do_subtree, void *d)
+       if (!(cp_walk_tree (stmt, find_any_await, &await_ptr, &visited)))
+ 	return NULL_TREE; /* Nothing special to do here.  */
+ 
++      /* Handle statement expressions.  */
++      if (TREE_CODE (expr) == EXPR_STMT)
++	{
++	  tree inner = EXPR_STMT_EXPR (expr);
++	  if (TREE_CODE (inner) == STATEMENT_LIST
++	      || TREE_CODE (inner) == BIND_EXPR)
++	    {
++	      res = cp_walk_tree (&EXPR_STMT_EXPR (expr),
++				  await_statement_walker, d, NULL);
++	      *do_subtree = 0;
++	      return res;
++	    }
++	}
++
+       visited.empty ();
+       awpts->saw_awaits = 0;
+       hash_set<tree> truth_aoif_to_expand;
+-- 
+2.39.2 (Apple Git-143)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index a6954a6..073283d 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,8 @@
+16	13 October 2024
+
+	+ 70_all_PR116506-coro.patch
+	+ 71_all_PR116914-coro.patch
+
 15	7 October 2024
 
 	- 71_all_c-Allow-references-to-internal-linkage-vars-in-C-11-.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-17  4:15 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-17  4:15 UTC (permalink / raw
  To: gentoo-commits
commit:     63001509ff89680da88fd497486bcb3add0c4f65
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 17 04:15:08 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Oct 17 04:15:08 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=63001509
15.0.0: add 72_all_PR117177-libcpp.patch
Fixes building glibc. Approved upstream but not yet merged.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117177-libcpp.patch | 234 +++++++++++++++++++++++++++++
 1 file changed, 234 insertions(+)
diff --git a/15.0.0/gentoo/72_all_PR117177-libcpp.patch b/15.0.0/gentoo/72_all_PR117177-libcpp.patch
new file mode 100644
index 0000000..1db42c9
--- /dev/null
+++ b/15.0.0/gentoo/72_all_PR117177-libcpp.patch
@@ -0,0 +1,234 @@
+From b2681b59424dd3a5fdf4101f8cc9eff60a5166b7 Mon Sep 17 00:00:00 2001
+Message-ID: <b2681b59424dd3a5fdf4101f8cc9eff60a5166b7.1729138476.git.sam@gentoo.org>
+From: Jakub Jelinek <jakub@redhat.com>
+Date: Wed, 16 Oct 2024 23:09:32 +0200
+Subject: [PATCH] c: Fix up speed up compilation of large char array
+ initializers when not using #embed [PR117177]
+
+Hi!
+
+Apparently my
+c: Speed up compilation of large char array initializers when not using #embed
+patch broke building glibc.
+
+The issue is that when using CPP_EMBED, we are guaranteed by the
+preprocessor that there is CPP_NUMBER CPP_COMMA before it and
+CPP_COMMA CPP_NUMBER after it (or CPP_COMMA CPP_EMBED), so RAW_DATA_CST
+never ends up at the end of arrays of unknown length.
+Now, the c_parser_initval optimization attempted to preserve that property
+rather than changing everything that e.g. inferes array number of elements
+from the initializer etc. to deal with RAW_DATA_CST at the end, but
+it didn't take into account the possibility that there could be
+CPP_COMMA followed by CPP_CLOSE_BRACE (where the CPP_COMMA is redundant).
+
+As we are peaking already at 4 tokens in that code, peeking more would
+require using raw tokens and that seems to be expensive doing it for
+every pair of tokens due to vec_free done when we are out of raw tokens.
+
+So, the following patch instead determines the case where we want
+another INTEGER_CST element after it after consuming the tokens, and just
+arranges for another process_init_element.
+
+Ok for trunk if this passes bootstrap/regtest?
+
+2024-10-16  Jakub Jelinek  <jakub@redhat.com>
+
+	PR c/117177
+gcc/c/
+	* c-parser.cc (c_parser_initval): Instead of doing
+	orig_len == INT_MAX checks before consuming tokens to set
+	last = 1, check it after consuming it and if not followed
+	by CPP_COMMA CPP_NUMBER, call process_init_element once
+	more with the last CPP_NUMBER.
+gcc/testsuite/
+	* c-c++-common/init-4.c: New test.
+---
+ gcc/c/c-parser.cc                   | 35 ++++++++---
+ gcc/testsuite/c-c++-common/init-4.c | 97 +++++++++++++++++++++++++++++
+ 2 files changed, 122 insertions(+), 10 deletions(-)
+ create mode 100644 gcc/testsuite/c-c++-common/init-4.c
+
+diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
+index e4381044e5c..090ab1cbc08 100644
+--- a/gcc/c/c-parser.cc
++++ b/gcc/c/c-parser.cc
+@@ -6529,6 +6529,7 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	unsigned int i;
+ 	gcc_checking_assert (len >= 64);
+ 	location_t last_loc = UNKNOWN_LOCATION;
++	location_t prev_loc = UNKNOWN_LOCATION;
+ 	for (i = 0; i < 64; ++i)
+ 	  {
+ 	    c_token *tok = c_parser_peek_nth_token_raw (parser, 1 + 2 * i);
+@@ -6544,6 +6545,7 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	    buf1[i] = (char) tree_to_uhwi (tok->value);
+ 	    if (i == 0)
+ 	      loc = tok->location;
++	    prev_loc = last_loc;
+ 	    last_loc = tok->location;
+ 	  }
+ 	if (i < 64)
+@@ -6567,6 +6569,7 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	unsigned int max_len = 131072 - offsetof (struct tree_string, str) - 1;
+ 	unsigned int orig_len = len;
+ 	unsigned int off = 0, last = 0;
++	unsigned char lastc = 0;
+ 	if (!wi::neg_p (wi::to_wide (val)) && wi::to_widest (val) <= UCHAR_MAX)
+ 	  off = 1;
+ 	len = MIN (len, max_len - off);
+@@ -6596,20 +6599,25 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	    if (tok2->type != CPP_COMMA && tok2->type != CPP_CLOSE_BRACE)
+ 	      break;
+ 	    buf2[i + off] = (char) tree_to_uhwi (tok->value);
+-	    /* If orig_len is INT_MAX, this can be flexible array member and
+-	       in that case we need to ensure another element which
+-	       for CPP_EMBED is normally guaranteed after it.  Include
+-	       that byte in the RAW_DATA_OWNER though, so it can be optimized
+-	       later.  */
+-	    if (tok2->type == CPP_CLOSE_BRACE && orig_len == INT_MAX)
+-	      {
+-		last = 1;
+-		break;
+-	      }
++	    prev_loc = last_loc;
+ 	    last_loc = tok->location;
+ 	    c_parser_consume_token (parser);
+ 	    c_parser_consume_token (parser);
+ 	  }
++	/* If orig_len is INT_MAX, this can be flexible array member and
++	   in that case we need to ensure another element which
++	   for CPP_EMBED is normally guaranteed after it.  Include
++	   that byte in the RAW_DATA_OWNER though, so it can be optimized
++	   later.  */
++	if (orig_len == INT_MAX
++	    && (!c_parser_next_token_is (parser, CPP_COMMA)
++		|| c_parser_peek_2nd_token (parser)->type != CPP_NUMBER))
++	  {
++	    --i;
++	    last = 1;
++	    std::swap (prev_loc, last_loc);
++	    lastc = (unsigned char) buf2[i + off];
++	  }
+ 	val = make_node (RAW_DATA_CST);
+ 	TREE_TYPE (val) = integer_type_node;
+ 	RAW_DATA_LENGTH (val) = i;
+@@ -6625,6 +6633,13 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	init.original_type = integer_type_node;
+ 	init.m_decimal = 0;
+ 	process_init_element (loc, init, false, braced_init_obstack);
++	if (last)
++	  {
++	    init.value = build_int_cst (integer_type_node, lastc);
++	    init.original_code = INTEGER_CST;
++	    set_c_expr_source_range (&init, prev_loc, prev_loc);
++	    process_init_element (prev_loc, init, false, braced_init_obstack);
++	  }
+       }
+ }
+ 
+diff --git a/gcc/testsuite/c-c++-common/init-4.c b/gcc/testsuite/c-c++-common/init-4.c
+new file mode 100644
+index 00000000000..d575a3f5a51
+--- /dev/null
++++ b/gcc/testsuite/c-c++-common/init-4.c
+@@ -0,0 +1,97 @@
++/* { dg-do run } */
++/* { dg-options "-O2" } */
++
++unsigned char a1[] = {
++  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
++  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
++  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
++  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
++  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
++  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
++  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
++  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00,
++  0xfa, 0xfb, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
++};
++unsigned char a2[] = {
++  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
++  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
++  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
++  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
++  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
++  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
++  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
++  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00
++};
++unsigned char a3[] = {
++  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
++  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
++  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
++  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
++  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
++  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
++  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
++  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00,
++};
++unsigned char a4[] = {
++  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
++  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
++  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
++  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
++  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
++  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
++  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
++  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00,
++  0xfa
++};
++unsigned char a5[] = {
++  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
++  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
++  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
++  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
++  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
++  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
++  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
++  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00,
++  0xfa,
++};
++unsigned char a6[] = {
++  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
++  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
++  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
++  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
++  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
++  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
++  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
++  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00,
++  0xfa, 0xfb
++};
++unsigned char a7[] = {
++  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
++  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
++  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
++  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
++  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
++  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
++  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
++  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00,
++  0xfa, 0xfb
++};
++
++int
++main ()
++{
++  if (sizeof (a1) != 72
++      || sizeof (a2) != 64
++      || __builtin_memcmp (a1, a2, 64) != 0
++      || sizeof (a3) != 64
++      || __builtin_memcmp (a1, a3, 64) != 0
++      || sizeof (a4) != 65
++      || __builtin_memcmp (a1, a4, 65) != 0
++      || sizeof (a5) != 65
++      || __builtin_memcmp (a1, a5, 65) != 0
++      || sizeof (a6) != 66
++      || __builtin_memcmp (a1, a6, 66) != 0
++      || sizeof (a7) != 66
++      || __builtin_memcmp (a1, a7, 66) != 0)
++    __builtin_abort ();
++}
+-- 
+2.47.0
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-17  5:01 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-17  5:01 UTC (permalink / raw
  To: gentoo-commits
commit:     15d55a133c02c17eb73a729f098a0b6fa6e70632
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 17 05:00:54 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Oct 17 05:00:54 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=15d55a13
15.0.0: drop 72_all_PR117177-libcpp.patch
Now merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117177-libcpp.patch | 234 -----------------------------
 1 file changed, 234 deletions(-)
diff --git a/15.0.0/gentoo/72_all_PR117177-libcpp.patch b/15.0.0/gentoo/72_all_PR117177-libcpp.patch
deleted file mode 100644
index 1db42c9..0000000
--- a/15.0.0/gentoo/72_all_PR117177-libcpp.patch
+++ /dev/null
@@ -1,234 +0,0 @@
-From b2681b59424dd3a5fdf4101f8cc9eff60a5166b7 Mon Sep 17 00:00:00 2001
-Message-ID: <b2681b59424dd3a5fdf4101f8cc9eff60a5166b7.1729138476.git.sam@gentoo.org>
-From: Jakub Jelinek <jakub@redhat.com>
-Date: Wed, 16 Oct 2024 23:09:32 +0200
-Subject: [PATCH] c: Fix up speed up compilation of large char array
- initializers when not using #embed [PR117177]
-
-Hi!
-
-Apparently my
-c: Speed up compilation of large char array initializers when not using #embed
-patch broke building glibc.
-
-The issue is that when using CPP_EMBED, we are guaranteed by the
-preprocessor that there is CPP_NUMBER CPP_COMMA before it and
-CPP_COMMA CPP_NUMBER after it (or CPP_COMMA CPP_EMBED), so RAW_DATA_CST
-never ends up at the end of arrays of unknown length.
-Now, the c_parser_initval optimization attempted to preserve that property
-rather than changing everything that e.g. inferes array number of elements
-from the initializer etc. to deal with RAW_DATA_CST at the end, but
-it didn't take into account the possibility that there could be
-CPP_COMMA followed by CPP_CLOSE_BRACE (where the CPP_COMMA is redundant).
-
-As we are peaking already at 4 tokens in that code, peeking more would
-require using raw tokens and that seems to be expensive doing it for
-every pair of tokens due to vec_free done when we are out of raw tokens.
-
-So, the following patch instead determines the case where we want
-another INTEGER_CST element after it after consuming the tokens, and just
-arranges for another process_init_element.
-
-Ok for trunk if this passes bootstrap/regtest?
-
-2024-10-16  Jakub Jelinek  <jakub@redhat.com>
-
-	PR c/117177
-gcc/c/
-	* c-parser.cc (c_parser_initval): Instead of doing
-	orig_len == INT_MAX checks before consuming tokens to set
-	last = 1, check it after consuming it and if not followed
-	by CPP_COMMA CPP_NUMBER, call process_init_element once
-	more with the last CPP_NUMBER.
-gcc/testsuite/
-	* c-c++-common/init-4.c: New test.
----
- gcc/c/c-parser.cc                   | 35 ++++++++---
- gcc/testsuite/c-c++-common/init-4.c | 97 +++++++++++++++++++++++++++++
- 2 files changed, 122 insertions(+), 10 deletions(-)
- create mode 100644 gcc/testsuite/c-c++-common/init-4.c
-
-diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
-index e4381044e5c..090ab1cbc08 100644
---- a/gcc/c/c-parser.cc
-+++ b/gcc/c/c-parser.cc
-@@ -6529,6 +6529,7 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	unsigned int i;
- 	gcc_checking_assert (len >= 64);
- 	location_t last_loc = UNKNOWN_LOCATION;
-+	location_t prev_loc = UNKNOWN_LOCATION;
- 	for (i = 0; i < 64; ++i)
- 	  {
- 	    c_token *tok = c_parser_peek_nth_token_raw (parser, 1 + 2 * i);
-@@ -6544,6 +6545,7 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	    buf1[i] = (char) tree_to_uhwi (tok->value);
- 	    if (i == 0)
- 	      loc = tok->location;
-+	    prev_loc = last_loc;
- 	    last_loc = tok->location;
- 	  }
- 	if (i < 64)
-@@ -6567,6 +6569,7 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	unsigned int max_len = 131072 - offsetof (struct tree_string, str) - 1;
- 	unsigned int orig_len = len;
- 	unsigned int off = 0, last = 0;
-+	unsigned char lastc = 0;
- 	if (!wi::neg_p (wi::to_wide (val)) && wi::to_widest (val) <= UCHAR_MAX)
- 	  off = 1;
- 	len = MIN (len, max_len - off);
-@@ -6596,20 +6599,25 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	    if (tok2->type != CPP_COMMA && tok2->type != CPP_CLOSE_BRACE)
- 	      break;
- 	    buf2[i + off] = (char) tree_to_uhwi (tok->value);
--	    /* If orig_len is INT_MAX, this can be flexible array member and
--	       in that case we need to ensure another element which
--	       for CPP_EMBED is normally guaranteed after it.  Include
--	       that byte in the RAW_DATA_OWNER though, so it can be optimized
--	       later.  */
--	    if (tok2->type == CPP_CLOSE_BRACE && orig_len == INT_MAX)
--	      {
--		last = 1;
--		break;
--	      }
-+	    prev_loc = last_loc;
- 	    last_loc = tok->location;
- 	    c_parser_consume_token (parser);
- 	    c_parser_consume_token (parser);
- 	  }
-+	/* If orig_len is INT_MAX, this can be flexible array member and
-+	   in that case we need to ensure another element which
-+	   for CPP_EMBED is normally guaranteed after it.  Include
-+	   that byte in the RAW_DATA_OWNER though, so it can be optimized
-+	   later.  */
-+	if (orig_len == INT_MAX
-+	    && (!c_parser_next_token_is (parser, CPP_COMMA)
-+		|| c_parser_peek_2nd_token (parser)->type != CPP_NUMBER))
-+	  {
-+	    --i;
-+	    last = 1;
-+	    std::swap (prev_loc, last_loc);
-+	    lastc = (unsigned char) buf2[i + off];
-+	  }
- 	val = make_node (RAW_DATA_CST);
- 	TREE_TYPE (val) = integer_type_node;
- 	RAW_DATA_LENGTH (val) = i;
-@@ -6625,6 +6633,13 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	init.original_type = integer_type_node;
- 	init.m_decimal = 0;
- 	process_init_element (loc, init, false, braced_init_obstack);
-+	if (last)
-+	  {
-+	    init.value = build_int_cst (integer_type_node, lastc);
-+	    init.original_code = INTEGER_CST;
-+	    set_c_expr_source_range (&init, prev_loc, prev_loc);
-+	    process_init_element (prev_loc, init, false, braced_init_obstack);
-+	  }
-       }
- }
- 
-diff --git a/gcc/testsuite/c-c++-common/init-4.c b/gcc/testsuite/c-c++-common/init-4.c
-new file mode 100644
-index 00000000000..d575a3f5a51
---- /dev/null
-+++ b/gcc/testsuite/c-c++-common/init-4.c
-@@ -0,0 +1,97 @@
-+/* { dg-do run } */
-+/* { dg-options "-O2" } */
-+
-+unsigned char a1[] = {
-+  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
-+  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
-+  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
-+  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
-+  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
-+  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
-+  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
-+  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00,
-+  0xfa, 0xfb, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-+};
-+unsigned char a2[] = {
-+  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
-+  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
-+  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
-+  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
-+  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
-+  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
-+  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
-+  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00
-+};
-+unsigned char a3[] = {
-+  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
-+  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
-+  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
-+  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
-+  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
-+  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
-+  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
-+  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00,
-+};
-+unsigned char a4[] = {
-+  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
-+  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
-+  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
-+  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
-+  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
-+  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
-+  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
-+  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00,
-+  0xfa
-+};
-+unsigned char a5[] = {
-+  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
-+  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
-+  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
-+  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
-+  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
-+  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
-+  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
-+  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00,
-+  0xfa,
-+};
-+unsigned char a6[] = {
-+  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
-+  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
-+  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
-+  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
-+  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
-+  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
-+  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
-+  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00,
-+  0xfa, 0xfb
-+};
-+unsigned char a7[] = {
-+  0xc8, 0xc9, 0xca, 0xcb, 0x00, 0xcd, 0xce, 0xcf,
-+  0x00, 0xd1, 0x00, 0xd3, 0xd4, 0x00, 0xd6, 0xd7,
-+  0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0x00, 0x00, 0xdf,
-+  0xe0, 0xe1, 0xe2, 0x00, 0xe4, 0xe5, 0xe6, 0xe7,
-+  0xe8, 0xe9, 0xea, 0xeb, 0x00, 0xed, 0xee, 0xef,
-+  0x00, 0xf1, 0x00, 0xf3, 0xf4, 0x00, 0xf6, 0xf7,
-+  0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0x00, 0xff,
-+  0x00, 0x00, 0xc3, 0xe3, 0x00, 0x00, 0x00, 0x00,
-+  0xfa, 0xfb
-+};
-+
-+int
-+main ()
-+{
-+  if (sizeof (a1) != 72
-+      || sizeof (a2) != 64
-+      || __builtin_memcmp (a1, a2, 64) != 0
-+      || sizeof (a3) != 64
-+      || __builtin_memcmp (a1, a3, 64) != 0
-+      || sizeof (a4) != 65
-+      || __builtin_memcmp (a1, a4, 65) != 0
-+      || sizeof (a5) != 65
-+      || __builtin_memcmp (a1, a5, 65) != 0
-+      || sizeof (a6) != 66
-+      || __builtin_memcmp (a1, a6, 66) != 0
-+      || sizeof (a7) != 66
-+      || __builtin_memcmp (a1, a7, 66) != 0)
-+    __builtin_abort ();
-+}
--- 
-2.47.0
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-17 23:03 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-17 23:03 UTC (permalink / raw
  To: gentoo-commits
commit:     e1ed90a71415a98a6d4c7d6efe03b5e0551fbb4c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 17 23:02:59 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Oct 17 23:02:59 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=e1ed90a7
15.0.0: add 72_all_PR117192-andn.patch
Bug: https://gcc.gnu.org/PR117192
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117192-andn.patch | 94 ++++++++++++++++++++++++++++++++
 1 file changed, 94 insertions(+)
diff --git a/15.0.0/gentoo/72_all_PR117192-andn.patch b/15.0.0/gentoo/72_all_PR117192-andn.patch
new file mode 100644
index 0000000..5593ae0
--- /dev/null
+++ b/15.0.0/gentoo/72_all_PR117192-andn.patch
@@ -0,0 +1,94 @@
+https://gcc.gnu.org/PR17192
+
+From 70f59d2a1c51bde085d8fc7df002918851e76c9c Mon Sep 17 00:00:00 2001
+From: "Cui, Lili" <lili.cui@intel.com>
+Date: Thu, 17 Oct 2024 08:50:38 +0800
+Subject: [PATCH] Support andn_optab for x86
+
+Add new andn pattern to match the new optab added by
+r15-1890-gf379596e0ba99d. Only enable 64bit, 128bit and
+256bit vector ANDN, X86-64 has mask mov instruction when
+avx512 is enabled.
+
+gcc/ChangeLog:
+
+	* config/i386/sse.md (andn<mode>3): New.
+	* config/i386/mmx.md (andn<mode>3): New.
+
+gcc/testsuite/ChangeLog:
+
+	* g++.target/i386/vect-cmp.C: New test.
+---
+ gcc/config/i386/mmx.md                   |  7 +++++++
+ gcc/config/i386/sse.md                   |  7 +++++++
+ gcc/testsuite/g++.target/i386/vect-cmp.C | 23 +++++++++++++++++++++++
+ 3 files changed, 37 insertions(+)
+ create mode 100644 gcc/testsuite/g++.target/i386/vect-cmp.C
+
+diff --git a/gcc/config/i386/mmx.md b/gcc/config/i386/mmx.md
+index 9d2a82c598e5..ef4ed8b501a1 100644
+--- a/gcc/config/i386/mmx.md
++++ b/gcc/config/i386/mmx.md
+@@ -4467,6 +4467,13 @@
+   operands[0] = lowpart_subreg (V16QImode, operands[0], <MODE>mode);
+ })
+ 
++(define_expand "andn<mode>3"
++  [(set (match_operand:MMXMODEI 0 "register_operand")
++        (and:MMXMODEI
++          (not:MMXMODEI (match_operand:MMXMODEI 1 "register_operand"))
++          (match_operand:MMXMODEI 2 "register_operand")))]
++  "TARGET_SSE2")
++
+ (define_insn "mmx_andnot<mode>3"
+   [(set (match_operand:MMXMODEI 0 "register_operand" "=y,x,x,v")
+ 	(and:MMXMODEI
+diff --git a/gcc/config/i386/sse.md b/gcc/config/i386/sse.md
+index a45b50ad7324..7be313346677 100644
+--- a/gcc/config/i386/sse.md
++++ b/gcc/config/i386/sse.md
+@@ -18438,6 +18438,13 @@
+ 	  (match_operand:VI_AVX2 2 "vector_operand")))]
+   "TARGET_SSE2")
+ 
++(define_expand "andn<mode>3"
++  [(set (match_operand:VI 0 "register_operand")
++	(and:VI
++	  (not:VI (match_operand:VI 2 "register_operand"))
++	  (match_operand:VI 1 "register_operand")))]
++  "TARGET_SSE2")
++
+ (define_expand "<sse2_avx2>_andnot<mode>3_mask"
+   [(set (match_operand:VI48_AVX512VL 0 "register_operand")
+ 	(vec_merge:VI48_AVX512VL
+diff --git a/gcc/testsuite/g++.target/i386/vect-cmp.C b/gcc/testsuite/g++.target/i386/vect-cmp.C
+new file mode 100644
+index 000000000000..c154474fa51c
+--- /dev/null
++++ b/gcc/testsuite/g++.target/i386/vect-cmp.C
+@@ -0,0 +1,23 @@
++/* { dg-do compile } */
++/* { dg-options "-O2 -march=x86-64-v3 -fdump-tree-optimized" } */
++
++#define vect8 __attribute__((vector_size(8) ))
++#define vect16 __attribute__((vector_size(16) ))
++#define vect32 __attribute__((vector_size(32) ))
++
++vect8 int bar0 (vect8 float a, vect8 float b, vect8 int c)
++{
++  return (a > b) ? 0 : c;
++}
++
++vect16 int bar1 (vect16 float a, vect16 float b, vect16 int c)
++{
++  return (a > b) ? 0 : c;
++}
++
++vect32 int bar2 (vect32 float a, vect32 float b, vect32 int c)
++{
++  return (a > b) ? 0 : c;
++}
++
++/* { dg-final { scan-tree-dump-times ".BIT_ANDN " 3 "optimized" { target { ! ia32 } } } } */
+-- 
+2.43.5
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-17 23:33 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-17 23:33 UTC (permalink / raw
  To: gentoo-commits
commit:     137934d3c0119acebb59614f6627e8b4fe299feb
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 17 23:33:01 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Oct 17 23:33:17 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=137934d3
15.0.0: fix 72_all_PR117192-andn.patch
Doh. Apply the patch, not the commit it's fixing...
Fixes: e1ed90a71415a98a6d4c7d6efe03b5e0551fbb4c
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117192-andn.patch | 98 ++++----------------------------
 1 file changed, 12 insertions(+), 86 deletions(-)
diff --git a/15.0.0/gentoo/72_all_PR117192-andn.patch b/15.0.0/gentoo/72_all_PR117192-andn.patch
index 5593ae0..f7706c1 100644
--- a/15.0.0/gentoo/72_all_PR117192-andn.patch
+++ b/15.0.0/gentoo/72_all_PR117192-andn.patch
@@ -1,94 +1,20 @@
 https://gcc.gnu.org/PR17192
-
-From 70f59d2a1c51bde085d8fc7df002918851e76c9c Mon Sep 17 00:00:00 2001
-From: "Cui, Lili" <lili.cui@intel.com>
-Date: Thu, 17 Oct 2024 08:50:38 +0800
-Subject: [PATCH] Support andn_optab for x86
-
-Add new andn pattern to match the new optab added by
-r15-1890-gf379596e0ba99d. Only enable 64bit, 128bit and
-256bit vector ANDN, X86-64 has mask mov instruction when
-avx512 is enabled.
-
-gcc/ChangeLog:
-
-	* config/i386/sse.md (andn<mode>3): New.
-	* config/i386/mmx.md (andn<mode>3): New.
-
-gcc/testsuite/ChangeLog:
-
-	* g++.target/i386/vect-cmp.C: New test.
----
- gcc/config/i386/mmx.md                   |  7 +++++++
- gcc/config/i386/sse.md                   |  7 +++++++
- gcc/testsuite/g++.target/i386/vect-cmp.C | 23 +++++++++++++++++++++++
- 3 files changed, 37 insertions(+)
- create mode 100644 gcc/testsuite/g++.target/i386/vect-cmp.C
+https://gcc.gnu.org/bugzilla/attachment.cgi?id=59373
 
 diff --git a/gcc/config/i386/mmx.md b/gcc/config/i386/mmx.md
-index 9d2a82c598e5..ef4ed8b501a1 100644
+index ef4ed8b501a..506f4cab6a8 100644
 --- a/gcc/config/i386/mmx.md
 +++ b/gcc/config/i386/mmx.md
-@@ -4467,6 +4467,13 @@
-   operands[0] = lowpart_subreg (V16QImode, operands[0], <MODE>mode);
- })
+@@ -4470,9 +4470,9 @@ (define_split
+ (define_expand "andn<mode>3"
+   [(set (match_operand:MMXMODEI 0 "register_operand")
+         (and:MMXMODEI
+-          (not:MMXMODEI (match_operand:MMXMODEI 1 "register_operand"))
+-          (match_operand:MMXMODEI 2 "register_operand")))]
+-  "TARGET_SSE2")
++          (not:MMXMODEI (match_operand:MMXMODEI 2 "register_operand"))
++          (match_operand:MMXMODEI 1 "register_operand")))]
++  "TARGET_MMX_WITH_SSE")
  
-+(define_expand "andn<mode>3"
-+  [(set (match_operand:MMXMODEI 0 "register_operand")
-+        (and:MMXMODEI
-+          (not:MMXMODEI (match_operand:MMXMODEI 1 "register_operand"))
-+          (match_operand:MMXMODEI 2 "register_operand")))]
-+  "TARGET_SSE2")
-+
  (define_insn "mmx_andnot<mode>3"
    [(set (match_operand:MMXMODEI 0 "register_operand" "=y,x,x,v")
- 	(and:MMXMODEI
-diff --git a/gcc/config/i386/sse.md b/gcc/config/i386/sse.md
-index a45b50ad7324..7be313346677 100644
---- a/gcc/config/i386/sse.md
-+++ b/gcc/config/i386/sse.md
-@@ -18438,6 +18438,13 @@
- 	  (match_operand:VI_AVX2 2 "vector_operand")))]
-   "TARGET_SSE2")
- 
-+(define_expand "andn<mode>3"
-+  [(set (match_operand:VI 0 "register_operand")
-+	(and:VI
-+	  (not:VI (match_operand:VI 2 "register_operand"))
-+	  (match_operand:VI 1 "register_operand")))]
-+  "TARGET_SSE2")
-+
- (define_expand "<sse2_avx2>_andnot<mode>3_mask"
-   [(set (match_operand:VI48_AVX512VL 0 "register_operand")
- 	(vec_merge:VI48_AVX512VL
-diff --git a/gcc/testsuite/g++.target/i386/vect-cmp.C b/gcc/testsuite/g++.target/i386/vect-cmp.C
-new file mode 100644
-index 000000000000..c154474fa51c
---- /dev/null
-+++ b/gcc/testsuite/g++.target/i386/vect-cmp.C
-@@ -0,0 +1,23 @@
-+/* { dg-do compile } */
-+/* { dg-options "-O2 -march=x86-64-v3 -fdump-tree-optimized" } */
-+
-+#define vect8 __attribute__((vector_size(8) ))
-+#define vect16 __attribute__((vector_size(16) ))
-+#define vect32 __attribute__((vector_size(32) ))
-+
-+vect8 int bar0 (vect8 float a, vect8 float b, vect8 int c)
-+{
-+  return (a > b) ? 0 : c;
-+}
-+
-+vect16 int bar1 (vect16 float a, vect16 float b, vect16 int c)
-+{
-+  return (a > b) ? 0 : c;
-+}
-+
-+vect32 int bar2 (vect32 float a, vect32 float b, vect32 int c)
-+{
-+  return (a > b) ? 0 : c;
-+}
-+
-+/* { dg-final { scan-tree-dump-times ".BIT_ANDN " 3 "optimized" { target { ! ia32 } } } } */
--- 
-2.43.5
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-18 10:35 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-18 10:35 UTC (permalink / raw
  To: gentoo-commits
commit:     462456df6da32e138cdc1e18df6e681cc2dc948a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 18 10:34:47 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Oct 18 10:34:47 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=462456df
15.0.0: revert some embed patches
Do as Jakub suggests at https://gcc.gnu.org/bugzilla/show_bug.cgi?id=117190#c3
and revert these for now until a fix can be applied.
Bug: https://gcc.gnu.org/PR117190
Bug: https://gcc.gnu.org/PR117199
Bug: https://gcc.gnu.org/PR117201
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...x-up-speed-up-compilation-of-large-char-a.patch |  97 ++++++++++
 ...eed-up-compilation-of-large-char-array-in.patch | 212 +++++++++++++++++++++
 2 files changed, 309 insertions(+)
diff --git a/15.0.0/gentoo/73_all_PR117190-Revert-c-Fix-up-speed-up-compilation-of-large-char-a.patch b/15.0.0/gentoo/73_all_PR117190-Revert-c-Fix-up-speed-up-compilation-of-large-char-a.patch
new file mode 100644
index 0000000..47f26cc
--- /dev/null
+++ b/15.0.0/gentoo/73_all_PR117190-Revert-c-Fix-up-speed-up-compilation-of-large-char-a.patch
@@ -0,0 +1,97 @@
+From bfec21e6cf88b0b64bfcc30d2f5ae3b3370e36e3 Mon Sep 17 00:00:00 2001
+Message-ID: <bfec21e6cf88b0b64bfcc30d2f5ae3b3370e36e3.1729247640.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Fri, 18 Oct 2024 11:31:20 +0100
+Subject: [PATCH 1/2] Revert "c: Fix up speed up compilation of large char
+ array initializers when not using #embed [PR117177]"
+
+This reverts commit 96ba5e5663d4390a7e69735ce3c9de657fc543fc.
+
+Keep the testcase.
+
+Bug: https://gcc.gnu.org/PR117190
+---
+ gcc/c/c-parser.cc | 35 ++++++++++-------------------------
+ 1 file changed, 10 insertions(+), 25 deletions(-)
+
+diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
+index 090ab1cbc088..e4381044e5cb 100644
+--- a/gcc/c/c-parser.cc
++++ b/gcc/c/c-parser.cc
+@@ -6529,7 +6529,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	unsigned int i;
+ 	gcc_checking_assert (len >= 64);
+ 	location_t last_loc = UNKNOWN_LOCATION;
+-	location_t prev_loc = UNKNOWN_LOCATION;
+ 	for (i = 0; i < 64; ++i)
+ 	  {
+ 	    c_token *tok = c_parser_peek_nth_token_raw (parser, 1 + 2 * i);
+@@ -6545,7 +6544,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	    buf1[i] = (char) tree_to_uhwi (tok->value);
+ 	    if (i == 0)
+ 	      loc = tok->location;
+-	    prev_loc = last_loc;
+ 	    last_loc = tok->location;
+ 	  }
+ 	if (i < 64)
+@@ -6569,7 +6567,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	unsigned int max_len = 131072 - offsetof (struct tree_string, str) - 1;
+ 	unsigned int orig_len = len;
+ 	unsigned int off = 0, last = 0;
+-	unsigned char lastc = 0;
+ 	if (!wi::neg_p (wi::to_wide (val)) && wi::to_widest (val) <= UCHAR_MAX)
+ 	  off = 1;
+ 	len = MIN (len, max_len - off);
+@@ -6599,25 +6596,20 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	    if (tok2->type != CPP_COMMA && tok2->type != CPP_CLOSE_BRACE)
+ 	      break;
+ 	    buf2[i + off] = (char) tree_to_uhwi (tok->value);
+-	    prev_loc = last_loc;
++	    /* If orig_len is INT_MAX, this can be flexible array member and
++	       in that case we need to ensure another element which
++	       for CPP_EMBED is normally guaranteed after it.  Include
++	       that byte in the RAW_DATA_OWNER though, so it can be optimized
++	       later.  */
++	    if (tok2->type == CPP_CLOSE_BRACE && orig_len == INT_MAX)
++	      {
++		last = 1;
++		break;
++	      }
+ 	    last_loc = tok->location;
+ 	    c_parser_consume_token (parser);
+ 	    c_parser_consume_token (parser);
+ 	  }
+-	/* If orig_len is INT_MAX, this can be flexible array member and
+-	   in that case we need to ensure another element which
+-	   for CPP_EMBED is normally guaranteed after it.  Include
+-	   that byte in the RAW_DATA_OWNER though, so it can be optimized
+-	   later.  */
+-	if (orig_len == INT_MAX
+-	    && (!c_parser_next_token_is (parser, CPP_COMMA)
+-		|| c_parser_peek_2nd_token (parser)->type != CPP_NUMBER))
+-	  {
+-	    --i;
+-	    last = 1;
+-	    std::swap (prev_loc, last_loc);
+-	    lastc = (unsigned char) buf2[i + off];
+-	  }
+ 	val = make_node (RAW_DATA_CST);
+ 	TREE_TYPE (val) = integer_type_node;
+ 	RAW_DATA_LENGTH (val) = i;
+@@ -6633,13 +6625,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	init.original_type = integer_type_node;
+ 	init.m_decimal = 0;
+ 	process_init_element (loc, init, false, braced_init_obstack);
+-	if (last)
+-	  {
+-	    init.value = build_int_cst (integer_type_node, lastc);
+-	    init.original_code = INTEGER_CST;
+-	    set_c_expr_source_range (&init, prev_loc, prev_loc);
+-	    process_init_element (prev_loc, init, false, braced_init_obstack);
+-	  }
+       }
+ }
+ 
+-- 
+2.47.0
+
diff --git a/15.0.0/gentoo/74_all_PR117190-Revert-c-Speed-up-compilation-of-large-char-array-in.patch b/15.0.0/gentoo/74_all_PR117190-Revert-c-Speed-up-compilation-of-large-char-array-in.patch
new file mode 100644
index 0000000..889c961
--- /dev/null
+++ b/15.0.0/gentoo/74_all_PR117190-Revert-c-Speed-up-compilation-of-large-char-array-in.patch
@@ -0,0 +1,212 @@
+From ec2844301e40a017a32b4f11f499d6db7629c6bf Mon Sep 17 00:00:00 2001
+Message-ID: <ec2844301e40a017a32b4f11f499d6db7629c6bf.1729247640.git.sam@gentoo.org>
+In-Reply-To: <bfec21e6cf88b0b64bfcc30d2f5ae3b3370e36e3.1729247640.git.sam@gentoo.org>
+References: <bfec21e6cf88b0b64bfcc30d2f5ae3b3370e36e3.1729247640.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Fri, 18 Oct 2024 11:31:27 +0100
+Subject: [PATCH 2/2] Revert "c: Speed up compilation of large char array
+ initializers when not using #embed"
+
+This reverts commit f9bac238840155e1539aa68daf1507ea63c9ed80.
+
+Keep the testcase.
+
+Bug: https://gcc.gnu.org/PR117190
+---
+ gcc/c/c-parser.cc | 118 ----------------------------------------------
+ gcc/c/c-tree.h    |   1 -
+ gcc/c/c-typeck.cc |  36 --------------
+ 3 files changed, 155 deletions(-)
+
+diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
+index e4381044e5cb..9518459a0a57 100644
+--- a/gcc/c/c-parser.cc
++++ b/gcc/c/c-parser.cc
+@@ -6507,125 +6507,7 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 					    (init.value))))
+ 	init = convert_lvalue_to_rvalue (loc, init, true, true, true);
+     }
+-  tree val = init.value;
+   process_init_element (loc, init, false, braced_init_obstack);
+-
+-  /* Attempt to optimize large char array initializers into RAW_DATA_CST
+-     to save compile time and memory even when not using #embed.  */
+-  static unsigned vals_to_ignore;
+-  if (vals_to_ignore)
+-    /* If earlier call determined there is certain number of CPP_COMMA
+-       CPP_NUMBER tokens with 0-255 int values, but not enough for
+-       RAW_DATA_CST to be beneficial, don't try to check it again until
+-       they are all parsed.  */
+-    --vals_to_ignore;
+-  else if (val
+-	   && TREE_CODE (val) == INTEGER_CST
+-	   && TREE_TYPE (val) == integer_type_node
+-	   && c_parser_next_token_is (parser, CPP_COMMA))
+-    if (unsigned int len = c_maybe_optimize_large_byte_initializer ())
+-      {
+-	char buf1[64];
+-	unsigned int i;
+-	gcc_checking_assert (len >= 64);
+-	location_t last_loc = UNKNOWN_LOCATION;
+-	for (i = 0; i < 64; ++i)
+-	  {
+-	    c_token *tok = c_parser_peek_nth_token_raw (parser, 1 + 2 * i);
+-	    if (tok->type != CPP_COMMA)
+-	      break;
+-	    tok = c_parser_peek_nth_token_raw (parser, 2 + 2 * i);
+-	    if (tok->type != CPP_NUMBER
+-		|| TREE_CODE (tok->value) != INTEGER_CST
+-		|| TREE_TYPE (tok->value) != integer_type_node
+-		|| wi::neg_p (wi::to_wide (tok->value))
+-		|| wi::to_widest (tok->value) > UCHAR_MAX)
+-	      break;
+-	    buf1[i] = (char) tree_to_uhwi (tok->value);
+-	    if (i == 0)
+-	      loc = tok->location;
+-	    last_loc = tok->location;
+-	  }
+-	if (i < 64)
+-	  {
+-	    vals_to_ignore = i;
+-	    return;
+-	  }
+-	c_token *tok = c_parser_peek_nth_token_raw (parser, 1 + 2 * i);
+-	/* If 64 CPP_COMMA CPP_NUMBER pairs are followed by CPP_CLOSE_BRACE,
+-	   punt if len is INT_MAX as that can mean this is a flexible array
+-	   member and in that case we need one CPP_NUMBER afterwards
+-	   (as guaranteed for CPP_EMBED).  */
+-	if (tok->type == CPP_CLOSE_BRACE && len != INT_MAX)
+-	  len = i;
+-	else if (tok->type != CPP_COMMA)
+-	  {
+-	    vals_to_ignore = i;
+-	    return;
+-	  }
+-	/* Ensure the STRING_CST fits into 128K.  */
+-	unsigned int max_len = 131072 - offsetof (struct tree_string, str) - 1;
+-	unsigned int orig_len = len;
+-	unsigned int off = 0, last = 0;
+-	if (!wi::neg_p (wi::to_wide (val)) && wi::to_widest (val) <= UCHAR_MAX)
+-	  off = 1;
+-	len = MIN (len, max_len - off);
+-	char *buf2 = XNEWVEC (char, len + off);
+-	if (off)
+-	  buf2[0] = (char) tree_to_uhwi (val);
+-	memcpy (buf2 + off, buf1, i);
+-	for (unsigned int j = 0; j < i; ++j)
+-	  {
+-	    c_parser_peek_token (parser);
+-	    c_parser_consume_token (parser);
+-	    c_parser_peek_token (parser);
+-	    c_parser_consume_token (parser);
+-	  }
+-	for (; i < len; ++i)
+-	  {
+-	    if (!c_parser_next_token_is (parser, CPP_COMMA))
+-	      break;
+-	    tok = c_parser_peek_2nd_token (parser);
+-	    if (tok->type != CPP_NUMBER
+-		|| TREE_CODE (tok->value) != INTEGER_CST
+-		|| TREE_TYPE (tok->value) != integer_type_node
+-		|| wi::neg_p (wi::to_wide (tok->value))
+-		|| wi::to_widest (tok->value) > UCHAR_MAX)
+-	      break;
+-	    c_token *tok2 = c_parser_peek_nth_token (parser, 3);
+-	    if (tok2->type != CPP_COMMA && tok2->type != CPP_CLOSE_BRACE)
+-	      break;
+-	    buf2[i + off] = (char) tree_to_uhwi (tok->value);
+-	    /* If orig_len is INT_MAX, this can be flexible array member and
+-	       in that case we need to ensure another element which
+-	       for CPP_EMBED is normally guaranteed after it.  Include
+-	       that byte in the RAW_DATA_OWNER though, so it can be optimized
+-	       later.  */
+-	    if (tok2->type == CPP_CLOSE_BRACE && orig_len == INT_MAX)
+-	      {
+-		last = 1;
+-		break;
+-	      }
+-	    last_loc = tok->location;
+-	    c_parser_consume_token (parser);
+-	    c_parser_consume_token (parser);
+-	  }
+-	val = make_node (RAW_DATA_CST);
+-	TREE_TYPE (val) = integer_type_node;
+-	RAW_DATA_LENGTH (val) = i;
+-	tree owner = build_string (i + off + last, buf2);
+-	XDELETEVEC (buf2);
+-	TREE_TYPE (owner) = build_array_type_nelts (unsigned_char_type_node,
+-						    i + off + last);
+-	RAW_DATA_OWNER (val) = owner;
+-	RAW_DATA_POINTER (val) = TREE_STRING_POINTER (owner) + off;
+-	init.value = val;
+-	set_c_expr_source_range (&init, loc, last_loc);
+-	init.original_code = RAW_DATA_CST;
+-	init.original_type = integer_type_node;
+-	init.m_decimal = 0;
+-	process_init_element (loc, init, false, braced_init_obstack);
+-      }
+ }
+ 
+ /* Parse a compound statement (possibly a function body) (C90 6.6.2,
+diff --git a/gcc/c/c-tree.h b/gcc/c/c-tree.h
+index bfdcb78bbcc1..e23d8e59ac4b 100644
+--- a/gcc/c/c-tree.h
++++ b/gcc/c/c-tree.h
+@@ -832,7 +832,6 @@ extern struct c_expr pop_init_level (location_t, int, struct obstack *,
+ 				     location_t);
+ extern void set_init_index (location_t, tree, tree, struct obstack *);
+ extern void set_init_label (location_t, tree, location_t, struct obstack *);
+-unsigned c_maybe_optimize_large_byte_initializer (void);
+ extern void process_init_element (location_t, struct c_expr, bool,
+ 				  struct obstack *);
+ extern tree build_compound_literal (location_t, tree, tree, bool,
+diff --git a/gcc/c/c-typeck.cc b/gcc/c/c-typeck.cc
+index 108ea5ca3e8c..36d0b23a3d72 100644
+--- a/gcc/c/c-typeck.cc
++++ b/gcc/c/c-typeck.cc
+@@ -11347,42 +11347,6 @@ maybe_split_raw_data (tree value, tree *raw_data)
+   return value;
+ }
+ 
+-/* Return non-zero if c_parser_initval should attempt to optimize
+-   large initializers into RAW_DATA_CST.  In that case return how
+-   many elements to optimize at most.  */
+-
+-unsigned
+-c_maybe_optimize_large_byte_initializer (void)
+-{
+-  if (!constructor_type
+-      || TREE_CODE (constructor_type) != ARRAY_TYPE
+-      || constructor_stack->implicit)
+-    return 0;
+-  tree elttype = TYPE_MAIN_VARIANT (TREE_TYPE (constructor_type));
+-  if (TREE_CODE (elttype) != INTEGER_TYPE
+-      && TREE_CODE (elttype) != BITINT_TYPE)
+-    return 0;
+-  if (TYPE_PRECISION (elttype) != CHAR_BIT
+-      || constructor_stack->replacement_value.value
+-      || (COMPLETE_TYPE_P (constructor_type)
+-	  && !poly_int_tree_p (TYPE_SIZE (constructor_type)))
+-      || constructor_range_stack)
+-    return 0;
+-  if (constructor_max_index == NULL_TREE)
+-    return INT_MAX;
+-  if (tree_int_cst_le (constructor_max_index, constructor_index)
+-      || integer_all_onesp (constructor_max_index))
+-    return 0;
+-  widest_int w = wi::to_widest (constructor_max_index);
+-  w -= wi::to_widest (constructor_index);
+-  w += 1;
+-  if (w < 64)
+-    return 0;
+-  if (w > INT_MAX)
+-    return INT_MAX;
+-  return w.to_uhwi ();
+-}
+-
+ /* Add one non-braced element to the current constructor level.
+    This adjusts the current position within the constructor's type.
+    This may also start or terminate implicit levels
+-- 
+2.47.0
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-18 14:05 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-18 14:05 UTC (permalink / raw
  To: gentoo-commits
commit:     a36914b3932f5ae93d9f18d445be959cd61f1dff
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 18 14:05:27 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Oct 18 14:05:27 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=a36914b3
15.0.0: drop 72_all_PR117192-andn.patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117192-andn.patch | 20 --------------------
 1 file changed, 20 deletions(-)
diff --git a/15.0.0/gentoo/72_all_PR117192-andn.patch b/15.0.0/gentoo/72_all_PR117192-andn.patch
deleted file mode 100644
index f7706c1..0000000
--- a/15.0.0/gentoo/72_all_PR117192-andn.patch
+++ /dev/null
@@ -1,20 +0,0 @@
-https://gcc.gnu.org/PR17192
-https://gcc.gnu.org/bugzilla/attachment.cgi?id=59373
-
-diff --git a/gcc/config/i386/mmx.md b/gcc/config/i386/mmx.md
-index ef4ed8b501a..506f4cab6a8 100644
---- a/gcc/config/i386/mmx.md
-+++ b/gcc/config/i386/mmx.md
-@@ -4470,9 +4470,9 @@ (define_split
- (define_expand "andn<mode>3"
-   [(set (match_operand:MMXMODEI 0 "register_operand")
-         (and:MMXMODEI
--          (not:MMXMODEI (match_operand:MMXMODEI 1 "register_operand"))
--          (match_operand:MMXMODEI 2 "register_operand")))]
--  "TARGET_SSE2")
-+          (not:MMXMODEI (match_operand:MMXMODEI 2 "register_operand"))
-+          (match_operand:MMXMODEI 1 "register_operand")))]
-+  "TARGET_MMX_WITH_SSE")
- 
- (define_insn "mmx_andnot<mode>3"
-   [(set (match_operand:MMXMODEI 0 "register_operand" "=y,x,x,v")
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-20 22:42 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-20 22:42 UTC (permalink / raw
  To: gentoo-commits
commit:     cc3680147a9d8db04f71bb6d4c30a5985e9deefe
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 20 22:42:13 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Oct 20 22:42:13 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=cc368014
15.0.0: cut patchset 17
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 073283d..52ceb20 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,8 @@
+17	20 October 2024
+
+	+ 73_all_PR117190-Revert-c-Fix-up-speed-up-compilation-of-large-char-a.patch
+	+ 74_all_PR117190-Revert-c-Speed-up-compilation-of-large-char-array-in.patch
+
 16	13 October 2024
 
 	+ 70_all_PR116506-coro.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-21 11:45 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-21 11:45 UTC (permalink / raw
  To: gentoo-commits
commit:     059d75a5509ca0a831a4aebb4f944fb6dc09a205
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 21 11:44:52 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Oct 21 11:44:52 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=059d75a5
15.0.0: add 75_all_PR117220-uninitialized-clang.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../75_all_PR117220-uninitialized-clang.patch      | 65 ++++++++++++++++++++++
 15.0.0/gentoo/README.history                       |  4 ++
 2 files changed, 69 insertions(+)
diff --git a/15.0.0/gentoo/75_all_PR117220-uninitialized-clang.patch b/15.0.0/gentoo/75_all_PR117220-uninitialized-clang.patch
new file mode 100644
index 0000000..f923cbd
--- /dev/null
+++ b/15.0.0/gentoo/75_all_PR117220-uninitialized-clang.patch
@@ -0,0 +1,65 @@
+From 8974ee300419c422f8d771343263c05af0a53a2a Mon Sep 17 00:00:00 2001
+Message-ID: <8974ee300419c422f8d771343263c05af0a53a2a.1729510984.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Mon, 21 Oct 2024 12:42:16 +0100
+Subject: [PATCH] libstdc++: fix stl_iterator.h for Clang
+
+libstdc++-v3/ChangeLog:
+	PR libstdc++/117220
+
+	* include/bits/stl_iterator.h: Fix attribute order for Clang.
+--- a/libstdc++-v3/include/bits/stl_iterator.h
++++ b/libstdc++-v3/include/bits/stl_iterator.h
+@@ -1077,13 +1077,13 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+ 
+       // Forward iterator requirements
+ 
+-      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+       _GLIBCXX_CONSTEXPR
+       reference
+       operator*() const _GLIBCXX_NOEXCEPT
+       { return *_M_current; }
+ 
+-      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+       _GLIBCXX_CONSTEXPR
+       pointer
+       operator->() const _GLIBCXX_NOEXCEPT
+@@ -1123,7 +1123,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+ 
+       // Random access iterator requirements
+ 
+-      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+       _GLIBCXX_CONSTEXPR
+       reference
+       operator[](difference_type __n) const _GLIBCXX_NOEXCEPT
+@@ -1135,7 +1135,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+       operator+=(difference_type __n) _GLIBCXX_NOEXCEPT
+       { _M_current += __n; return *this; }
+ 
+-      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+       _GLIBCXX_CONSTEXPR
+       __normal_iterator
+       operator+(difference_type __n) const _GLIBCXX_NOEXCEPT
+@@ -1147,13 +1147,13 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+       operator-=(difference_type __n) _GLIBCXX_NOEXCEPT
+       { _M_current -= __n; return *this; }
+ 
+-      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+       _GLIBCXX_CONSTEXPR
+       __normal_iterator
+       operator-(difference_type __n) const _GLIBCXX_NOEXCEPT
+       { return __normal_iterator(_M_current - __n); }
+ 
+-      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+       _GLIBCXX_CONSTEXPR
+       const _Iterator&
+       base() const _GLIBCXX_NOEXCEPT
+-- 
+2.47.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 52ceb20..7cc59ef 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+18	21 October 2024
+
+	+ 75_all_PR117220-uninitialized-clang.patch
+
 17	20 October 2024
 
 	+ 73_all_PR117190-Revert-c-Fix-up-speed-up-compilation-of-large-char-a.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-21 12:26 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-21 12:26 UTC (permalink / raw
  To: gentoo-commits
commit:     7aa175a83520bb175c4588301daaa9ab14117bc7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 21 12:26:03 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Oct 21 12:26:03 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=7aa175a8
15.0.0: drop 75_all_PR117220-uninitialized-clang.patch
A variant is now merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../75_all_PR117220-uninitialized-clang.patch      | 65 ----------------------
 1 file changed, 65 deletions(-)
diff --git a/15.0.0/gentoo/75_all_PR117220-uninitialized-clang.patch b/15.0.0/gentoo/75_all_PR117220-uninitialized-clang.patch
deleted file mode 100644
index f923cbd..0000000
--- a/15.0.0/gentoo/75_all_PR117220-uninitialized-clang.patch
+++ /dev/null
@@ -1,65 +0,0 @@
-From 8974ee300419c422f8d771343263c05af0a53a2a Mon Sep 17 00:00:00 2001
-Message-ID: <8974ee300419c422f8d771343263c05af0a53a2a.1729510984.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Mon, 21 Oct 2024 12:42:16 +0100
-Subject: [PATCH] libstdc++: fix stl_iterator.h for Clang
-
-libstdc++-v3/ChangeLog:
-	PR libstdc++/117220
-
-	* include/bits/stl_iterator.h: Fix attribute order for Clang.
---- a/libstdc++-v3/include/bits/stl_iterator.h
-+++ b/libstdc++-v3/include/bits/stl_iterator.h
-@@ -1077,13 +1077,13 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
- 
-       // Forward iterator requirements
- 
--      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-       _GLIBCXX_CONSTEXPR
-       reference
-       operator*() const _GLIBCXX_NOEXCEPT
-       { return *_M_current; }
- 
--      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-       _GLIBCXX_CONSTEXPR
-       pointer
-       operator->() const _GLIBCXX_NOEXCEPT
-@@ -1123,7 +1123,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
- 
-       // Random access iterator requirements
- 
--      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-       _GLIBCXX_CONSTEXPR
-       reference
-       operator[](difference_type __n) const _GLIBCXX_NOEXCEPT
-@@ -1135,7 +1135,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-       operator+=(difference_type __n) _GLIBCXX_NOEXCEPT
-       { _M_current += __n; return *this; }
- 
--      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-       _GLIBCXX_CONSTEXPR
-       __normal_iterator
-       operator+(difference_type __n) const _GLIBCXX_NOEXCEPT
-@@ -1147,13 +1147,13 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-       operator-=(difference_type __n) _GLIBCXX_NOEXCEPT
-       { _M_current -= __n; return *this; }
- 
--      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-       _GLIBCXX_CONSTEXPR
-       __normal_iterator
-       operator-(difference_type __n) const _GLIBCXX_NOEXCEPT
-       { return __normal_iterator(_M_current - __n); }
- 
--      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-       _GLIBCXX_CONSTEXPR
-       const _Iterator&
-       base() const _GLIBCXX_NOEXCEPT
--- 
-2.47.0
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-21 12:27 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-21 12:27 UTC (permalink / raw
  To: gentoo-commits
commit:     5ecbc3c9e907f74fa12599e0fa5672553cc8db15
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 21 12:27:28 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Oct 21 12:27:28 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=5ecbc3c9
15.0.0: update 75_all_PR117220-uninitialized-clang.patch
... to roll one more patchset with it in, then we can drop it for live.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../75_all_PR117220-uninitialized-clang.patch      | 223 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   4 +
 2 files changed, 227 insertions(+)
diff --git a/15.0.0/gentoo/75_all_PR117220-uninitialized-clang.patch b/15.0.0/gentoo/75_all_PR117220-uninitialized-clang.patch
new file mode 100644
index 0000000..a6acc09
--- /dev/null
+++ b/15.0.0/gentoo/75_all_PR117220-uninitialized-clang.patch
@@ -0,0 +1,223 @@
+From cba80691251efccf44ab9aecb26558319605c9ea Mon Sep 17 00:00:00 2001
+Message-ID: <cba80691251efccf44ab9aecb26558319605c9ea.1729513605.git.sam@gentoo.org>
+From: Jonathan Wakely <jwakely@redhat.com>
+Date: Mon, 21 Oct 2024 12:09:36 +0100
+Subject: [PATCH] libstdc++: Fix order of [[...]] and __attribute__((...))
+ attrs [PR117220]
+
+GCC allows these in either order, but Clang doesn't like the C++11-style
+[[__nodiscard__]] coming after __attribute__((__always_inline__)).
+
+libstdc++-v3/ChangeLog:
+
+	PR libstdc++/117220
+	* include/bits/stl_iterator.h: Move _GLIBCXX_NODISCARD
+	annotations after __attribute__((__always_inline__)).
+--- a/libstdc++-v3/include/bits/stl_iterator.h
++++ b/libstdc++-v3/include/bits/stl_iterator.h
+@@ -1077,13 +1077,13 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+ 
+       // Forward iterator requirements
+ 
+-      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+       _GLIBCXX_CONSTEXPR
+       reference
+       operator*() const _GLIBCXX_NOEXCEPT
+       { return *_M_current; }
+ 
+-      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+       _GLIBCXX_CONSTEXPR
+       pointer
+       operator->() const _GLIBCXX_NOEXCEPT
+@@ -1123,7 +1123,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+ 
+       // Random access iterator requirements
+ 
+-      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+       _GLIBCXX_CONSTEXPR
+       reference
+       operator[](difference_type __n) const _GLIBCXX_NOEXCEPT
+@@ -1135,7 +1135,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+       operator+=(difference_type __n) _GLIBCXX_NOEXCEPT
+       { _M_current += __n; return *this; }
+ 
+-      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+       _GLIBCXX_CONSTEXPR
+       __normal_iterator
+       operator+(difference_type __n) const _GLIBCXX_NOEXCEPT
+@@ -1147,13 +1147,13 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+       operator-=(difference_type __n) _GLIBCXX_NOEXCEPT
+       { _M_current -= __n; return *this; }
+ 
+-      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+       _GLIBCXX_CONSTEXPR
+       __normal_iterator
+       operator-(difference_type __n) const _GLIBCXX_NOEXCEPT
+       { return __normal_iterator(_M_current - __n); }
+ 
+-      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+       _GLIBCXX_CONSTEXPR
+       const _Iterator&
+       base() const _GLIBCXX_NOEXCEPT
+@@ -1209,7 +1209,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+ #else
+    // Forward iterator requirements
+   template<typename _IteratorL, typename _IteratorR, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
+     inline bool
+     operator==(const __normal_iterator<_IteratorL, _Container>& __lhs,
+ 	       const __normal_iterator<_IteratorR, _Container>& __rhs)
+@@ -1217,7 +1217,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+     { return __lhs.base() == __rhs.base(); }
+ 
+   template<typename _Iterator, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
+     inline bool
+     operator==(const __normal_iterator<_Iterator, _Container>& __lhs,
+ 	       const __normal_iterator<_Iterator, _Container>& __rhs)
+@@ -1225,7 +1225,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+     { return __lhs.base() == __rhs.base(); }
+ 
+   template<typename _IteratorL, typename _IteratorR, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
+     inline bool
+     operator!=(const __normal_iterator<_IteratorL, _Container>& __lhs,
+ 	       const __normal_iterator<_IteratorR, _Container>& __rhs)
+@@ -1233,7 +1233,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+     { return __lhs.base() != __rhs.base(); }
+ 
+   template<typename _Iterator, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
+     inline bool
+     operator!=(const __normal_iterator<_Iterator, _Container>& __lhs,
+ 	       const __normal_iterator<_Iterator, _Container>& __rhs)
+@@ -1242,7 +1242,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+ 
+   // Random access iterator requirements
+   template<typename _IteratorL, typename _IteratorR, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
+     inline bool
+     operator<(const __normal_iterator<_IteratorL, _Container>& __lhs,
+ 	      const __normal_iterator<_IteratorR, _Container>& __rhs)
+@@ -1250,7 +1250,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+     { return __lhs.base() < __rhs.base(); }
+ 
+   template<typename _Iterator, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX20_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX20_CONSTEXPR
+     inline bool
+     operator<(const __normal_iterator<_Iterator, _Container>& __lhs,
+ 	      const __normal_iterator<_Iterator, _Container>& __rhs)
+@@ -1258,7 +1258,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+     { return __lhs.base() < __rhs.base(); }
+ 
+   template<typename _IteratorL, typename _IteratorR, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
+     inline bool
+     operator>(const __normal_iterator<_IteratorL, _Container>& __lhs,
+ 	      const __normal_iterator<_IteratorR, _Container>& __rhs)
+@@ -1266,7 +1266,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+     { return __lhs.base() > __rhs.base(); }
+ 
+   template<typename _Iterator, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
+     inline bool
+     operator>(const __normal_iterator<_Iterator, _Container>& __lhs,
+ 	      const __normal_iterator<_Iterator, _Container>& __rhs)
+@@ -1274,7 +1274,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+     { return __lhs.base() > __rhs.base(); }
+ 
+   template<typename _IteratorL, typename _IteratorR, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
+     inline bool
+     operator<=(const __normal_iterator<_IteratorL, _Container>& __lhs,
+ 	       const __normal_iterator<_IteratorR, _Container>& __rhs)
+@@ -1282,7 +1282,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+     { return __lhs.base() <= __rhs.base(); }
+ 
+   template<typename _Iterator, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
+     inline bool
+     operator<=(const __normal_iterator<_Iterator, _Container>& __lhs,
+ 	       const __normal_iterator<_Iterator, _Container>& __rhs)
+@@ -1290,7 +1290,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+     { return __lhs.base() <= __rhs.base(); }
+ 
+   template<typename _IteratorL, typename _IteratorR, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
+     inline bool
+     operator>=(const __normal_iterator<_IteratorL, _Container>& __lhs,
+ 	       const __normal_iterator<_IteratorR, _Container>& __rhs)
+@@ -1298,7 +1298,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+     { return __lhs.base() >= __rhs.base(); }
+ 
+   template<typename _Iterator, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
+     inline bool
+     operator>=(const __normal_iterator<_Iterator, _Container>& __lhs,
+ 	       const __normal_iterator<_Iterator, _Container>& __rhs)
+@@ -1326,7 +1326,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+     { return __lhs.base() - __rhs.base(); }
+ 
+   template<typename _Iterator, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
+     inline typename __normal_iterator<_Iterator, _Container>::difference_type
+     operator-(const __normal_iterator<_Iterator, _Container>& __lhs,
+ 	      const __normal_iterator<_Iterator, _Container>& __rhs)
+@@ -1334,7 +1334,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+     { return __lhs.base() - __rhs.base(); }
+ 
+   template<typename _Iterator, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
+     inline __normal_iterator<_Iterator, _Container>
+     operator+(typename __normal_iterator<_Iterator, _Container>::difference_type
+ 	      __n, const __normal_iterator<_Iterator, _Container>& __i)
+@@ -2990,7 +2990,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+   // Unwrap a __normal_iterator to get the underlying iterator
+   // (usually a pointer). See uses in std::copy, std::fill, etc.
+   template<typename _Iterator, typename _Container>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+     _GLIBCXX20_CONSTEXPR
+     inline _Iterator
+     __niter_base(__gnu_cxx::__normal_iterator<_Iterator, _Container> __it)
+@@ -2999,7 +2999,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+ 
+   // Fallback implementation used for iterators that can't be unwrapped.
+   template<typename _Iterator>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+     _GLIBCXX20_CONSTEXPR
+     inline _Iterator
+     __niter_base(_Iterator __it)
+@@ -3071,7 +3071,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
+ 
+   // No need to wrap, iterator already has the right type.
+   template<typename _Iterator>
+-    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
++    _GLIBCXX_NODISCARD __attribute__((__always_inline__))
+     _GLIBCXX20_CONSTEXPR
+     inline _Iterator
+     __niter_wrap(const _Iterator&, _Iterator __res)
+-- 
+2.47.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 7cc59ef..da76e70 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+19	21 October 2024
+
+	U 75_all_PR117220-uninitialized-clang.patch
+
 18	21 October 2024
 
 	+ 75_all_PR117220-uninitialized-clang.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-21 12:33 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-21 12:33 UTC (permalink / raw
  To: gentoo-commits
commit:     cea84be3fb8da9cc115f6fd5a4836c45356f6dc3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 21 12:32:54 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Oct 21 12:32:54 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=cea84be3
15.0.0: drop 75_all_PR117220-uninitialized-clang.patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../75_all_PR117220-uninitialized-clang.patch      | 223 ---------------------
 1 file changed, 223 deletions(-)
diff --git a/15.0.0/gentoo/75_all_PR117220-uninitialized-clang.patch b/15.0.0/gentoo/75_all_PR117220-uninitialized-clang.patch
deleted file mode 100644
index a6acc09..0000000
--- a/15.0.0/gentoo/75_all_PR117220-uninitialized-clang.patch
+++ /dev/null
@@ -1,223 +0,0 @@
-From cba80691251efccf44ab9aecb26558319605c9ea Mon Sep 17 00:00:00 2001
-Message-ID: <cba80691251efccf44ab9aecb26558319605c9ea.1729513605.git.sam@gentoo.org>
-From: Jonathan Wakely <jwakely@redhat.com>
-Date: Mon, 21 Oct 2024 12:09:36 +0100
-Subject: [PATCH] libstdc++: Fix order of [[...]] and __attribute__((...))
- attrs [PR117220]
-
-GCC allows these in either order, but Clang doesn't like the C++11-style
-[[__nodiscard__]] coming after __attribute__((__always_inline__)).
-
-libstdc++-v3/ChangeLog:
-
-	PR libstdc++/117220
-	* include/bits/stl_iterator.h: Move _GLIBCXX_NODISCARD
-	annotations after __attribute__((__always_inline__)).
---- a/libstdc++-v3/include/bits/stl_iterator.h
-+++ b/libstdc++-v3/include/bits/stl_iterator.h
-@@ -1077,13 +1077,13 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
- 
-       // Forward iterator requirements
- 
--      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-       _GLIBCXX_CONSTEXPR
-       reference
-       operator*() const _GLIBCXX_NOEXCEPT
-       { return *_M_current; }
- 
--      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-       _GLIBCXX_CONSTEXPR
-       pointer
-       operator->() const _GLIBCXX_NOEXCEPT
-@@ -1123,7 +1123,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
- 
-       // Random access iterator requirements
- 
--      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-       _GLIBCXX_CONSTEXPR
-       reference
-       operator[](difference_type __n) const _GLIBCXX_NOEXCEPT
-@@ -1135,7 +1135,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-       operator+=(difference_type __n) _GLIBCXX_NOEXCEPT
-       { _M_current += __n; return *this; }
- 
--      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-       _GLIBCXX_CONSTEXPR
-       __normal_iterator
-       operator+(difference_type __n) const _GLIBCXX_NOEXCEPT
-@@ -1147,13 +1147,13 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-       operator-=(difference_type __n) _GLIBCXX_NOEXCEPT
-       { _M_current -= __n; return *this; }
- 
--      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-       _GLIBCXX_CONSTEXPR
-       __normal_iterator
-       operator-(difference_type __n) const _GLIBCXX_NOEXCEPT
-       { return __normal_iterator(_M_current - __n); }
- 
--      __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+      _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-       _GLIBCXX_CONSTEXPR
-       const _Iterator&
-       base() const _GLIBCXX_NOEXCEPT
-@@ -1209,7 +1209,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
- #else
-    // Forward iterator requirements
-   template<typename _IteratorL, typename _IteratorR, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
-     inline bool
-     operator==(const __normal_iterator<_IteratorL, _Container>& __lhs,
- 	       const __normal_iterator<_IteratorR, _Container>& __rhs)
-@@ -1217,7 +1217,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-     { return __lhs.base() == __rhs.base(); }
- 
-   template<typename _Iterator, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
-     inline bool
-     operator==(const __normal_iterator<_Iterator, _Container>& __lhs,
- 	       const __normal_iterator<_Iterator, _Container>& __rhs)
-@@ -1225,7 +1225,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-     { return __lhs.base() == __rhs.base(); }
- 
-   template<typename _IteratorL, typename _IteratorR, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
-     inline bool
-     operator!=(const __normal_iterator<_IteratorL, _Container>& __lhs,
- 	       const __normal_iterator<_IteratorR, _Container>& __rhs)
-@@ -1233,7 +1233,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-     { return __lhs.base() != __rhs.base(); }
- 
-   template<typename _Iterator, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
-     inline bool
-     operator!=(const __normal_iterator<_Iterator, _Container>& __lhs,
- 	       const __normal_iterator<_Iterator, _Container>& __rhs)
-@@ -1242,7 +1242,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
- 
-   // Random access iterator requirements
-   template<typename _IteratorL, typename _IteratorR, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
-     inline bool
-     operator<(const __normal_iterator<_IteratorL, _Container>& __lhs,
- 	      const __normal_iterator<_IteratorR, _Container>& __rhs)
-@@ -1250,7 +1250,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-     { return __lhs.base() < __rhs.base(); }
- 
-   template<typename _Iterator, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX20_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX20_CONSTEXPR
-     inline bool
-     operator<(const __normal_iterator<_Iterator, _Container>& __lhs,
- 	      const __normal_iterator<_Iterator, _Container>& __rhs)
-@@ -1258,7 +1258,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-     { return __lhs.base() < __rhs.base(); }
- 
-   template<typename _IteratorL, typename _IteratorR, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
-     inline bool
-     operator>(const __normal_iterator<_IteratorL, _Container>& __lhs,
- 	      const __normal_iterator<_IteratorR, _Container>& __rhs)
-@@ -1266,7 +1266,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-     { return __lhs.base() > __rhs.base(); }
- 
-   template<typename _Iterator, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
-     inline bool
-     operator>(const __normal_iterator<_Iterator, _Container>& __lhs,
- 	      const __normal_iterator<_Iterator, _Container>& __rhs)
-@@ -1274,7 +1274,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-     { return __lhs.base() > __rhs.base(); }
- 
-   template<typename _IteratorL, typename _IteratorR, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
-     inline bool
-     operator<=(const __normal_iterator<_IteratorL, _Container>& __lhs,
- 	       const __normal_iterator<_IteratorR, _Container>& __rhs)
-@@ -1282,7 +1282,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-     { return __lhs.base() <= __rhs.base(); }
- 
-   template<typename _Iterator, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
-     inline bool
-     operator<=(const __normal_iterator<_Iterator, _Container>& __lhs,
- 	       const __normal_iterator<_Iterator, _Container>& __rhs)
-@@ -1290,7 +1290,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-     { return __lhs.base() <= __rhs.base(); }
- 
-   template<typename _IteratorL, typename _IteratorR, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
-     inline bool
-     operator>=(const __normal_iterator<_IteratorL, _Container>& __lhs,
- 	       const __normal_iterator<_IteratorR, _Container>& __rhs)
-@@ -1298,7 +1298,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-     { return __lhs.base() >= __rhs.base(); }
- 
-   template<typename _Iterator, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
-     inline bool
-     operator>=(const __normal_iterator<_Iterator, _Container>& __lhs,
- 	       const __normal_iterator<_Iterator, _Container>& __rhs)
-@@ -1326,7 +1326,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-     { return __lhs.base() - __rhs.base(); }
- 
-   template<typename _Iterator, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
-     inline typename __normal_iterator<_Iterator, _Container>::difference_type
-     operator-(const __normal_iterator<_Iterator, _Container>& __lhs,
- 	      const __normal_iterator<_Iterator, _Container>& __rhs)
-@@ -1334,7 +1334,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-     { return __lhs.base() - __rhs.base(); }
- 
-   template<typename _Iterator, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD _GLIBCXX_CONSTEXPR
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__)) _GLIBCXX_CONSTEXPR
-     inline __normal_iterator<_Iterator, _Container>
-     operator+(typename __normal_iterator<_Iterator, _Container>::difference_type
- 	      __n, const __normal_iterator<_Iterator, _Container>& __i)
-@@ -2990,7 +2990,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
-   // Unwrap a __normal_iterator to get the underlying iterator
-   // (usually a pointer). See uses in std::copy, std::fill, etc.
-   template<typename _Iterator, typename _Container>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-     _GLIBCXX20_CONSTEXPR
-     inline _Iterator
-     __niter_base(__gnu_cxx::__normal_iterator<_Iterator, _Container> __it)
-@@ -2999,7 +2999,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
- 
-   // Fallback implementation used for iterators that can't be unwrapped.
-   template<typename _Iterator>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-     _GLIBCXX20_CONSTEXPR
-     inline _Iterator
-     __niter_base(_Iterator __it)
-@@ -3071,7 +3071,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
- 
-   // No need to wrap, iterator already has the right type.
-   template<typename _Iterator>
--    __attribute__((__always_inline__)) _GLIBCXX_NODISCARD
-+    _GLIBCXX_NODISCARD __attribute__((__always_inline__))
-     _GLIBCXX20_CONSTEXPR
-     inline _Iterator
-     __niter_wrap(const _Iterator&, _Iterator __res)
--- 
-2.47.0
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-22 18:34 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-22 18:34 UTC (permalink / raw
  To: gentoo-commits
commit:     a243737dd99899c96fa69256022d1d94a1d91c92
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 22 18:33:44 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct 22 18:33:44 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=a243737d
15.0.0: drop obsolete embed patches
It's fixed now so no need for reverts.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...x-up-speed-up-compilation-of-large-char-a.patch |  97 ----------
 ...eed-up-compilation-of-large-char-array-in.patch | 212 ---------------------
 15.0.0/gentoo/README.history                       |   5 +
 3 files changed, 5 insertions(+), 309 deletions(-)
diff --git a/15.0.0/gentoo/73_all_PR117190-Revert-c-Fix-up-speed-up-compilation-of-large-char-a.patch b/15.0.0/gentoo/73_all_PR117190-Revert-c-Fix-up-speed-up-compilation-of-large-char-a.patch
deleted file mode 100644
index 47f26cc..0000000
--- a/15.0.0/gentoo/73_all_PR117190-Revert-c-Fix-up-speed-up-compilation-of-large-char-a.patch
+++ /dev/null
@@ -1,97 +0,0 @@
-From bfec21e6cf88b0b64bfcc30d2f5ae3b3370e36e3 Mon Sep 17 00:00:00 2001
-Message-ID: <bfec21e6cf88b0b64bfcc30d2f5ae3b3370e36e3.1729247640.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Fri, 18 Oct 2024 11:31:20 +0100
-Subject: [PATCH 1/2] Revert "c: Fix up speed up compilation of large char
- array initializers when not using #embed [PR117177]"
-
-This reverts commit 96ba5e5663d4390a7e69735ce3c9de657fc543fc.
-
-Keep the testcase.
-
-Bug: https://gcc.gnu.org/PR117190
----
- gcc/c/c-parser.cc | 35 ++++++++++-------------------------
- 1 file changed, 10 insertions(+), 25 deletions(-)
-
-diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
-index 090ab1cbc088..e4381044e5cb 100644
---- a/gcc/c/c-parser.cc
-+++ b/gcc/c/c-parser.cc
-@@ -6529,7 +6529,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	unsigned int i;
- 	gcc_checking_assert (len >= 64);
- 	location_t last_loc = UNKNOWN_LOCATION;
--	location_t prev_loc = UNKNOWN_LOCATION;
- 	for (i = 0; i < 64; ++i)
- 	  {
- 	    c_token *tok = c_parser_peek_nth_token_raw (parser, 1 + 2 * i);
-@@ -6545,7 +6544,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	    buf1[i] = (char) tree_to_uhwi (tok->value);
- 	    if (i == 0)
- 	      loc = tok->location;
--	    prev_loc = last_loc;
- 	    last_loc = tok->location;
- 	  }
- 	if (i < 64)
-@@ -6569,7 +6567,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	unsigned int max_len = 131072 - offsetof (struct tree_string, str) - 1;
- 	unsigned int orig_len = len;
- 	unsigned int off = 0, last = 0;
--	unsigned char lastc = 0;
- 	if (!wi::neg_p (wi::to_wide (val)) && wi::to_widest (val) <= UCHAR_MAX)
- 	  off = 1;
- 	len = MIN (len, max_len - off);
-@@ -6599,25 +6596,20 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	    if (tok2->type != CPP_COMMA && tok2->type != CPP_CLOSE_BRACE)
- 	      break;
- 	    buf2[i + off] = (char) tree_to_uhwi (tok->value);
--	    prev_loc = last_loc;
-+	    /* If orig_len is INT_MAX, this can be flexible array member and
-+	       in that case we need to ensure another element which
-+	       for CPP_EMBED is normally guaranteed after it.  Include
-+	       that byte in the RAW_DATA_OWNER though, so it can be optimized
-+	       later.  */
-+	    if (tok2->type == CPP_CLOSE_BRACE && orig_len == INT_MAX)
-+	      {
-+		last = 1;
-+		break;
-+	      }
- 	    last_loc = tok->location;
- 	    c_parser_consume_token (parser);
- 	    c_parser_consume_token (parser);
- 	  }
--	/* If orig_len is INT_MAX, this can be flexible array member and
--	   in that case we need to ensure another element which
--	   for CPP_EMBED is normally guaranteed after it.  Include
--	   that byte in the RAW_DATA_OWNER though, so it can be optimized
--	   later.  */
--	if (orig_len == INT_MAX
--	    && (!c_parser_next_token_is (parser, CPP_COMMA)
--		|| c_parser_peek_2nd_token (parser)->type != CPP_NUMBER))
--	  {
--	    --i;
--	    last = 1;
--	    std::swap (prev_loc, last_loc);
--	    lastc = (unsigned char) buf2[i + off];
--	  }
- 	val = make_node (RAW_DATA_CST);
- 	TREE_TYPE (val) = integer_type_node;
- 	RAW_DATA_LENGTH (val) = i;
-@@ -6633,13 +6625,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	init.original_type = integer_type_node;
- 	init.m_decimal = 0;
- 	process_init_element (loc, init, false, braced_init_obstack);
--	if (last)
--	  {
--	    init.value = build_int_cst (integer_type_node, lastc);
--	    init.original_code = INTEGER_CST;
--	    set_c_expr_source_range (&init, prev_loc, prev_loc);
--	    process_init_element (prev_loc, init, false, braced_init_obstack);
--	  }
-       }
- }
- 
--- 
-2.47.0
-
diff --git a/15.0.0/gentoo/74_all_PR117190-Revert-c-Speed-up-compilation-of-large-char-array-in.patch b/15.0.0/gentoo/74_all_PR117190-Revert-c-Speed-up-compilation-of-large-char-array-in.patch
deleted file mode 100644
index 889c961..0000000
--- a/15.0.0/gentoo/74_all_PR117190-Revert-c-Speed-up-compilation-of-large-char-array-in.patch
+++ /dev/null
@@ -1,212 +0,0 @@
-From ec2844301e40a017a32b4f11f499d6db7629c6bf Mon Sep 17 00:00:00 2001
-Message-ID: <ec2844301e40a017a32b4f11f499d6db7629c6bf.1729247640.git.sam@gentoo.org>
-In-Reply-To: <bfec21e6cf88b0b64bfcc30d2f5ae3b3370e36e3.1729247640.git.sam@gentoo.org>
-References: <bfec21e6cf88b0b64bfcc30d2f5ae3b3370e36e3.1729247640.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Fri, 18 Oct 2024 11:31:27 +0100
-Subject: [PATCH 2/2] Revert "c: Speed up compilation of large char array
- initializers when not using #embed"
-
-This reverts commit f9bac238840155e1539aa68daf1507ea63c9ed80.
-
-Keep the testcase.
-
-Bug: https://gcc.gnu.org/PR117190
----
- gcc/c/c-parser.cc | 118 ----------------------------------------------
- gcc/c/c-tree.h    |   1 -
- gcc/c/c-typeck.cc |  36 --------------
- 3 files changed, 155 deletions(-)
-
-diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
-index e4381044e5cb..9518459a0a57 100644
---- a/gcc/c/c-parser.cc
-+++ b/gcc/c/c-parser.cc
-@@ -6507,125 +6507,7 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 					    (init.value))))
- 	init = convert_lvalue_to_rvalue (loc, init, true, true, true);
-     }
--  tree val = init.value;
-   process_init_element (loc, init, false, braced_init_obstack);
--
--  /* Attempt to optimize large char array initializers into RAW_DATA_CST
--     to save compile time and memory even when not using #embed.  */
--  static unsigned vals_to_ignore;
--  if (vals_to_ignore)
--    /* If earlier call determined there is certain number of CPP_COMMA
--       CPP_NUMBER tokens with 0-255 int values, but not enough for
--       RAW_DATA_CST to be beneficial, don't try to check it again until
--       they are all parsed.  */
--    --vals_to_ignore;
--  else if (val
--	   && TREE_CODE (val) == INTEGER_CST
--	   && TREE_TYPE (val) == integer_type_node
--	   && c_parser_next_token_is (parser, CPP_COMMA))
--    if (unsigned int len = c_maybe_optimize_large_byte_initializer ())
--      {
--	char buf1[64];
--	unsigned int i;
--	gcc_checking_assert (len >= 64);
--	location_t last_loc = UNKNOWN_LOCATION;
--	for (i = 0; i < 64; ++i)
--	  {
--	    c_token *tok = c_parser_peek_nth_token_raw (parser, 1 + 2 * i);
--	    if (tok->type != CPP_COMMA)
--	      break;
--	    tok = c_parser_peek_nth_token_raw (parser, 2 + 2 * i);
--	    if (tok->type != CPP_NUMBER
--		|| TREE_CODE (tok->value) != INTEGER_CST
--		|| TREE_TYPE (tok->value) != integer_type_node
--		|| wi::neg_p (wi::to_wide (tok->value))
--		|| wi::to_widest (tok->value) > UCHAR_MAX)
--	      break;
--	    buf1[i] = (char) tree_to_uhwi (tok->value);
--	    if (i == 0)
--	      loc = tok->location;
--	    last_loc = tok->location;
--	  }
--	if (i < 64)
--	  {
--	    vals_to_ignore = i;
--	    return;
--	  }
--	c_token *tok = c_parser_peek_nth_token_raw (parser, 1 + 2 * i);
--	/* If 64 CPP_COMMA CPP_NUMBER pairs are followed by CPP_CLOSE_BRACE,
--	   punt if len is INT_MAX as that can mean this is a flexible array
--	   member and in that case we need one CPP_NUMBER afterwards
--	   (as guaranteed for CPP_EMBED).  */
--	if (tok->type == CPP_CLOSE_BRACE && len != INT_MAX)
--	  len = i;
--	else if (tok->type != CPP_COMMA)
--	  {
--	    vals_to_ignore = i;
--	    return;
--	  }
--	/* Ensure the STRING_CST fits into 128K.  */
--	unsigned int max_len = 131072 - offsetof (struct tree_string, str) - 1;
--	unsigned int orig_len = len;
--	unsigned int off = 0, last = 0;
--	if (!wi::neg_p (wi::to_wide (val)) && wi::to_widest (val) <= UCHAR_MAX)
--	  off = 1;
--	len = MIN (len, max_len - off);
--	char *buf2 = XNEWVEC (char, len + off);
--	if (off)
--	  buf2[0] = (char) tree_to_uhwi (val);
--	memcpy (buf2 + off, buf1, i);
--	for (unsigned int j = 0; j < i; ++j)
--	  {
--	    c_parser_peek_token (parser);
--	    c_parser_consume_token (parser);
--	    c_parser_peek_token (parser);
--	    c_parser_consume_token (parser);
--	  }
--	for (; i < len; ++i)
--	  {
--	    if (!c_parser_next_token_is (parser, CPP_COMMA))
--	      break;
--	    tok = c_parser_peek_2nd_token (parser);
--	    if (tok->type != CPP_NUMBER
--		|| TREE_CODE (tok->value) != INTEGER_CST
--		|| TREE_TYPE (tok->value) != integer_type_node
--		|| wi::neg_p (wi::to_wide (tok->value))
--		|| wi::to_widest (tok->value) > UCHAR_MAX)
--	      break;
--	    c_token *tok2 = c_parser_peek_nth_token (parser, 3);
--	    if (tok2->type != CPP_COMMA && tok2->type != CPP_CLOSE_BRACE)
--	      break;
--	    buf2[i + off] = (char) tree_to_uhwi (tok->value);
--	    /* If orig_len is INT_MAX, this can be flexible array member and
--	       in that case we need to ensure another element which
--	       for CPP_EMBED is normally guaranteed after it.  Include
--	       that byte in the RAW_DATA_OWNER though, so it can be optimized
--	       later.  */
--	    if (tok2->type == CPP_CLOSE_BRACE && orig_len == INT_MAX)
--	      {
--		last = 1;
--		break;
--	      }
--	    last_loc = tok->location;
--	    c_parser_consume_token (parser);
--	    c_parser_consume_token (parser);
--	  }
--	val = make_node (RAW_DATA_CST);
--	TREE_TYPE (val) = integer_type_node;
--	RAW_DATA_LENGTH (val) = i;
--	tree owner = build_string (i + off + last, buf2);
--	XDELETEVEC (buf2);
--	TREE_TYPE (owner) = build_array_type_nelts (unsigned_char_type_node,
--						    i + off + last);
--	RAW_DATA_OWNER (val) = owner;
--	RAW_DATA_POINTER (val) = TREE_STRING_POINTER (owner) + off;
--	init.value = val;
--	set_c_expr_source_range (&init, loc, last_loc);
--	init.original_code = RAW_DATA_CST;
--	init.original_type = integer_type_node;
--	init.m_decimal = 0;
--	process_init_element (loc, init, false, braced_init_obstack);
--      }
- }
- 
- /* Parse a compound statement (possibly a function body) (C90 6.6.2,
-diff --git a/gcc/c/c-tree.h b/gcc/c/c-tree.h
-index bfdcb78bbcc1..e23d8e59ac4b 100644
---- a/gcc/c/c-tree.h
-+++ b/gcc/c/c-tree.h
-@@ -832,7 +832,6 @@ extern struct c_expr pop_init_level (location_t, int, struct obstack *,
- 				     location_t);
- extern void set_init_index (location_t, tree, tree, struct obstack *);
- extern void set_init_label (location_t, tree, location_t, struct obstack *);
--unsigned c_maybe_optimize_large_byte_initializer (void);
- extern void process_init_element (location_t, struct c_expr, bool,
- 				  struct obstack *);
- extern tree build_compound_literal (location_t, tree, tree, bool,
-diff --git a/gcc/c/c-typeck.cc b/gcc/c/c-typeck.cc
-index 108ea5ca3e8c..36d0b23a3d72 100644
---- a/gcc/c/c-typeck.cc
-+++ b/gcc/c/c-typeck.cc
-@@ -11347,42 +11347,6 @@ maybe_split_raw_data (tree value, tree *raw_data)
-   return value;
- }
- 
--/* Return non-zero if c_parser_initval should attempt to optimize
--   large initializers into RAW_DATA_CST.  In that case return how
--   many elements to optimize at most.  */
--
--unsigned
--c_maybe_optimize_large_byte_initializer (void)
--{
--  if (!constructor_type
--      || TREE_CODE (constructor_type) != ARRAY_TYPE
--      || constructor_stack->implicit)
--    return 0;
--  tree elttype = TYPE_MAIN_VARIANT (TREE_TYPE (constructor_type));
--  if (TREE_CODE (elttype) != INTEGER_TYPE
--      && TREE_CODE (elttype) != BITINT_TYPE)
--    return 0;
--  if (TYPE_PRECISION (elttype) != CHAR_BIT
--      || constructor_stack->replacement_value.value
--      || (COMPLETE_TYPE_P (constructor_type)
--	  && !poly_int_tree_p (TYPE_SIZE (constructor_type)))
--      || constructor_range_stack)
--    return 0;
--  if (constructor_max_index == NULL_TREE)
--    return INT_MAX;
--  if (tree_int_cst_le (constructor_max_index, constructor_index)
--      || integer_all_onesp (constructor_max_index))
--    return 0;
--  widest_int w = wi::to_widest (constructor_max_index);
--  w -= wi::to_widest (constructor_index);
--  w += 1;
--  if (w < 64)
--    return 0;
--  if (w > INT_MAX)
--    return INT_MAX;
--  return w.to_uhwi ();
--}
--
- /* Add one non-braced element to the current constructor level.
-    This adjusts the current position within the constructor's type.
-    This may also start or terminate implicit levels
--- 
-2.47.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index da76e70..bc7c1e6 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,8 @@
+20	????
+
+	- 73_all_PR117190-Revert-c-Fix-up-speed-up-compilation-of-large-char-a.patch
+	- 74_all_PR117190-Revert-c-Speed-up-compilation-of-large-char-array-in.patch
+
 19	21 October 2024
 
 	U 75_all_PR117220-uninitialized-clang.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-22 19:09 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-22 19:09 UTC (permalink / raw
  To: gentoo-commits
commit:     52de78302a3c40e11a16185917bf8bb4bccfd199
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 22 19:09:05 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct 22 19:09:05 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=52de7830
15.0.0: add 72_all_PR117190.patch
This patch isn't yet merged but should be soon.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117190.patch | 179 ++++++++++++++++++++++++++++++++++++
 1 file changed, 179 insertions(+)
diff --git a/15.0.0/gentoo/72_all_PR117190.patch b/15.0.0/gentoo/72_all_PR117190.patch
new file mode 100644
index 0000000..497d788
--- /dev/null
+++ b/15.0.0/gentoo/72_all_PR117190.patch
@@ -0,0 +1,179 @@
+From 756a3f3aad7200052d9aee207717c9766dce8be1 Mon Sep 17 00:00:00 2001
+Message-ID: <756a3f3aad7200052d9aee207717c9766dce8be1.1729624110.git.sam@gentoo.org>
+From: Jakub Jelinek <jakub@redhat.com>
+Date: Tue, 22 Oct 2024 20:03:35 +0200
+Subject: [PATCH] c: Better fix for speed up compilation of large char array
+ initializers when not using #embed [PR117190]
+
+On Wed, Oct 16, 2024 at 11:09:32PM +0200, Jakub Jelinek wrote:
+> Apparently my
+> c: Speed up compilation of large char array initializers when not using #embed
+> patch broke building glibc.
+>
+> The issue is that when using CPP_EMBED, we are guaranteed by the
+> preprocessor that there is CPP_NUMBER CPP_COMMA before it and
+> CPP_COMMA CPP_NUMBER after it (or CPP_COMMA CPP_EMBED), so RAW_DATA_CST
+> never ends up at the end of arrays of unknown length.
+> Now, the c_parser_initval optimization attempted to preserve that property
+> rather than changing everything that e.g. inferes array number of elements
+> from the initializer etc. to deal with RAW_DATA_CST at the end, but
+> it didn't take into account the possibility that there could be
+> CPP_COMMA followed by CPP_CLOSE_BRACE (where the CPP_COMMA is redundant).
+>
+> As we are peaking already at 4 tokens in that code, peeking more would
+> require using raw tokens and that seems to be expensive doing it for
+> every pair of tokens due to vec_free done when we are out of raw tokens.
+
+Sorry for rushing the previous patch too much, turns out I was wrong,
+given that the c_parser_peek_nth_token numbering is 1 based, we can peek
+also with c_parser_peek_nth_token (parser, 4) and the loop actually peeked
+just at 3 tokens, not 4.
+
+So, I think it is better to revert the previous patch (but keep the new
+test) and instead peek the 4th non-raw token, which is what the following
+patch does.
+
+Additionally, PR117190 shows one further spot which missed the peek of
+the token after CPP_COMMA, in case it is incomplete array with exactly 65
+elements with redundant comma after it, which this patch handles too.
+
+Bootstrapped/regtested on x86_64-linux, i686-linux, powerpc64le-linux
+and powerpc64-linux, ok for trunk?
+
+2024-10-22  Jakub Jelinek  <jakub@redhat.com>
+
+	PR c/117190
+gcc/c/
+	* c-parser.cc (c_parser_initval): Revert 2024-10-17 changes.
+	Instead peek the 4th token and if it is not CPP_NUMBER,
+	handle it like 3rd token CPP_CLOSE_BRACE for orig_len == INT_MAX.
+	Also, check (2 + 2 * i)th raw token for the orig_len == INT_MAX
+	case and punt if it is not CPP_NUMBER.
+gcc/testsuite/
+	* c-c++-common/init-5.c: New test.
+---
+ gcc/c/c-parser.cc                   | 42 +++++++++++------------------
+ gcc/testsuite/c-c++-common/init-5.c | 19 +++++++++++++
+ 2 files changed, 35 insertions(+), 26 deletions(-)
+ create mode 100644 gcc/testsuite/c-c++-common/init-5.c
+
+diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
+index 090ab1cbc088..3f2d7ddc5c42 100644
+--- a/gcc/c/c-parser.cc
++++ b/gcc/c/c-parser.cc
+@@ -6529,7 +6529,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	unsigned int i;
+ 	gcc_checking_assert (len >= 64);
+ 	location_t last_loc = UNKNOWN_LOCATION;
+-	location_t prev_loc = UNKNOWN_LOCATION;
+ 	for (i = 0; i < 64; ++i)
+ 	  {
+ 	    c_token *tok = c_parser_peek_nth_token_raw (parser, 1 + 2 * i);
+@@ -6545,7 +6544,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	    buf1[i] = (char) tree_to_uhwi (tok->value);
+ 	    if (i == 0)
+ 	      loc = tok->location;
+-	    prev_loc = last_loc;
+ 	    last_loc = tok->location;
+ 	  }
+ 	if (i < 64)
+@@ -6560,7 +6558,9 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	   (as guaranteed for CPP_EMBED).  */
+ 	if (tok->type == CPP_CLOSE_BRACE && len != INT_MAX)
+ 	  len = i;
+-	else if (tok->type != CPP_COMMA)
++	else if (tok->type != CPP_COMMA
++		 || (c_parser_peek_nth_token_raw (parser, 2 + 2 * i)->type
++		     != CPP_NUMBER))
+ 	  {
+ 	    vals_to_ignore = i;
+ 	    return;
+@@ -6569,7 +6569,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	unsigned int max_len = 131072 - offsetof (struct tree_string, str) - 1;
+ 	unsigned int orig_len = len;
+ 	unsigned int off = 0, last = 0;
+-	unsigned char lastc = 0;
+ 	if (!wi::neg_p (wi::to_wide (val)) && wi::to_widest (val) <= UCHAR_MAX)
+ 	  off = 1;
+ 	len = MIN (len, max_len - off);
+@@ -6599,25 +6598,23 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	    if (tok2->type != CPP_COMMA && tok2->type != CPP_CLOSE_BRACE)
+ 	      break;
+ 	    buf2[i + off] = (char) tree_to_uhwi (tok->value);
+-	    prev_loc = last_loc;
++	    /* If orig_len is INT_MAX, this can be flexible array member and
++	       in that case we need to ensure another element which
++	       for CPP_EMBED is normally guaranteed after it.  Include
++	       that byte in the RAW_DATA_OWNER though, so it can be optimized
++	       later.  */
++	    if (orig_len == INT_MAX
++		&& (tok2->type == CPP_CLOSE_BRACE
++		    || (c_parser_peek_nth_token (parser, 4)->type
++			!= CPP_NUMBER)))
++	      {
++		last = 1;
++		break;
++	      }
+ 	    last_loc = tok->location;
+ 	    c_parser_consume_token (parser);
+ 	    c_parser_consume_token (parser);
+ 	  }
+-	/* If orig_len is INT_MAX, this can be flexible array member and
+-	   in that case we need to ensure another element which
+-	   for CPP_EMBED is normally guaranteed after it.  Include
+-	   that byte in the RAW_DATA_OWNER though, so it can be optimized
+-	   later.  */
+-	if (orig_len == INT_MAX
+-	    && (!c_parser_next_token_is (parser, CPP_COMMA)
+-		|| c_parser_peek_2nd_token (parser)->type != CPP_NUMBER))
+-	  {
+-	    --i;
+-	    last = 1;
+-	    std::swap (prev_loc, last_loc);
+-	    lastc = (unsigned char) buf2[i + off];
+-	  }
+ 	val = make_node (RAW_DATA_CST);
+ 	TREE_TYPE (val) = integer_type_node;
+ 	RAW_DATA_LENGTH (val) = i;
+@@ -6633,13 +6630,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
+ 	init.original_type = integer_type_node;
+ 	init.m_decimal = 0;
+ 	process_init_element (loc, init, false, braced_init_obstack);
+-	if (last)
+-	  {
+-	    init.value = build_int_cst (integer_type_node, lastc);
+-	    init.original_code = INTEGER_CST;
+-	    set_c_expr_source_range (&init, prev_loc, prev_loc);
+-	    process_init_element (prev_loc, init, false, braced_init_obstack);
+-	  }
+       }
+ }
+ 
+diff --git a/gcc/testsuite/c-c++-common/init-5.c b/gcc/testsuite/c-c++-common/init-5.c
+new file mode 100644
+index 000000000000..61b6cdb97e2f
+--- /dev/null
++++ b/gcc/testsuite/c-c++-common/init-5.c
+@@ -0,0 +1,19 @@
++/* PR c/117190 */
++/* { dg-do run } */
++/* { dg-options "-O2" } */
++
++struct S { char d[]; } v = {
++{ 8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++  0, }
++};
++
++int
++main ()
++{
++  for (int i = 0; i < 65; ++i)
++    if (v.d[i] != (i == 0 ? 8 : 0))
++      __builtin_abort ();
++}
+-- 
+2.47.0
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-23 15:40 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-23 15:40 UTC (permalink / raw
  To: gentoo-commits
commit:     d4278761ff6c0c703c8cf4d105cac664e15a0df8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 23 15:39:45 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Oct 23 15:39:45 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=d4278761
15.0.0: drop 72_all_PR117190.patch
Merged upstream now.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117190.patch | 179 ------------------------------------
 1 file changed, 179 deletions(-)
diff --git a/15.0.0/gentoo/72_all_PR117190.patch b/15.0.0/gentoo/72_all_PR117190.patch
deleted file mode 100644
index 497d788..0000000
--- a/15.0.0/gentoo/72_all_PR117190.patch
+++ /dev/null
@@ -1,179 +0,0 @@
-From 756a3f3aad7200052d9aee207717c9766dce8be1 Mon Sep 17 00:00:00 2001
-Message-ID: <756a3f3aad7200052d9aee207717c9766dce8be1.1729624110.git.sam@gentoo.org>
-From: Jakub Jelinek <jakub@redhat.com>
-Date: Tue, 22 Oct 2024 20:03:35 +0200
-Subject: [PATCH] c: Better fix for speed up compilation of large char array
- initializers when not using #embed [PR117190]
-
-On Wed, Oct 16, 2024 at 11:09:32PM +0200, Jakub Jelinek wrote:
-> Apparently my
-> c: Speed up compilation of large char array initializers when not using #embed
-> patch broke building glibc.
->
-> The issue is that when using CPP_EMBED, we are guaranteed by the
-> preprocessor that there is CPP_NUMBER CPP_COMMA before it and
-> CPP_COMMA CPP_NUMBER after it (or CPP_COMMA CPP_EMBED), so RAW_DATA_CST
-> never ends up at the end of arrays of unknown length.
-> Now, the c_parser_initval optimization attempted to preserve that property
-> rather than changing everything that e.g. inferes array number of elements
-> from the initializer etc. to deal with RAW_DATA_CST at the end, but
-> it didn't take into account the possibility that there could be
-> CPP_COMMA followed by CPP_CLOSE_BRACE (where the CPP_COMMA is redundant).
->
-> As we are peaking already at 4 tokens in that code, peeking more would
-> require using raw tokens and that seems to be expensive doing it for
-> every pair of tokens due to vec_free done when we are out of raw tokens.
-
-Sorry for rushing the previous patch too much, turns out I was wrong,
-given that the c_parser_peek_nth_token numbering is 1 based, we can peek
-also with c_parser_peek_nth_token (parser, 4) and the loop actually peeked
-just at 3 tokens, not 4.
-
-So, I think it is better to revert the previous patch (but keep the new
-test) and instead peek the 4th non-raw token, which is what the following
-patch does.
-
-Additionally, PR117190 shows one further spot which missed the peek of
-the token after CPP_COMMA, in case it is incomplete array with exactly 65
-elements with redundant comma after it, which this patch handles too.
-
-Bootstrapped/regtested on x86_64-linux, i686-linux, powerpc64le-linux
-and powerpc64-linux, ok for trunk?
-
-2024-10-22  Jakub Jelinek  <jakub@redhat.com>
-
-	PR c/117190
-gcc/c/
-	* c-parser.cc (c_parser_initval): Revert 2024-10-17 changes.
-	Instead peek the 4th token and if it is not CPP_NUMBER,
-	handle it like 3rd token CPP_CLOSE_BRACE for orig_len == INT_MAX.
-	Also, check (2 + 2 * i)th raw token for the orig_len == INT_MAX
-	case and punt if it is not CPP_NUMBER.
-gcc/testsuite/
-	* c-c++-common/init-5.c: New test.
----
- gcc/c/c-parser.cc                   | 42 +++++++++++------------------
- gcc/testsuite/c-c++-common/init-5.c | 19 +++++++++++++
- 2 files changed, 35 insertions(+), 26 deletions(-)
- create mode 100644 gcc/testsuite/c-c++-common/init-5.c
-
-diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
-index 090ab1cbc088..3f2d7ddc5c42 100644
---- a/gcc/c/c-parser.cc
-+++ b/gcc/c/c-parser.cc
-@@ -6529,7 +6529,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	unsigned int i;
- 	gcc_checking_assert (len >= 64);
- 	location_t last_loc = UNKNOWN_LOCATION;
--	location_t prev_loc = UNKNOWN_LOCATION;
- 	for (i = 0; i < 64; ++i)
- 	  {
- 	    c_token *tok = c_parser_peek_nth_token_raw (parser, 1 + 2 * i);
-@@ -6545,7 +6544,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	    buf1[i] = (char) tree_to_uhwi (tok->value);
- 	    if (i == 0)
- 	      loc = tok->location;
--	    prev_loc = last_loc;
- 	    last_loc = tok->location;
- 	  }
- 	if (i < 64)
-@@ -6560,7 +6558,9 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	   (as guaranteed for CPP_EMBED).  */
- 	if (tok->type == CPP_CLOSE_BRACE && len != INT_MAX)
- 	  len = i;
--	else if (tok->type != CPP_COMMA)
-+	else if (tok->type != CPP_COMMA
-+		 || (c_parser_peek_nth_token_raw (parser, 2 + 2 * i)->type
-+		     != CPP_NUMBER))
- 	  {
- 	    vals_to_ignore = i;
- 	    return;
-@@ -6569,7 +6569,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	unsigned int max_len = 131072 - offsetof (struct tree_string, str) - 1;
- 	unsigned int orig_len = len;
- 	unsigned int off = 0, last = 0;
--	unsigned char lastc = 0;
- 	if (!wi::neg_p (wi::to_wide (val)) && wi::to_widest (val) <= UCHAR_MAX)
- 	  off = 1;
- 	len = MIN (len, max_len - off);
-@@ -6599,25 +6598,23 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	    if (tok2->type != CPP_COMMA && tok2->type != CPP_CLOSE_BRACE)
- 	      break;
- 	    buf2[i + off] = (char) tree_to_uhwi (tok->value);
--	    prev_loc = last_loc;
-+	    /* If orig_len is INT_MAX, this can be flexible array member and
-+	       in that case we need to ensure another element which
-+	       for CPP_EMBED is normally guaranteed after it.  Include
-+	       that byte in the RAW_DATA_OWNER though, so it can be optimized
-+	       later.  */
-+	    if (orig_len == INT_MAX
-+		&& (tok2->type == CPP_CLOSE_BRACE
-+		    || (c_parser_peek_nth_token (parser, 4)->type
-+			!= CPP_NUMBER)))
-+	      {
-+		last = 1;
-+		break;
-+	      }
- 	    last_loc = tok->location;
- 	    c_parser_consume_token (parser);
- 	    c_parser_consume_token (parser);
- 	  }
--	/* If orig_len is INT_MAX, this can be flexible array member and
--	   in that case we need to ensure another element which
--	   for CPP_EMBED is normally guaranteed after it.  Include
--	   that byte in the RAW_DATA_OWNER though, so it can be optimized
--	   later.  */
--	if (orig_len == INT_MAX
--	    && (!c_parser_next_token_is (parser, CPP_COMMA)
--		|| c_parser_peek_2nd_token (parser)->type != CPP_NUMBER))
--	  {
--	    --i;
--	    last = 1;
--	    std::swap (prev_loc, last_loc);
--	    lastc = (unsigned char) buf2[i + off];
--	  }
- 	val = make_node (RAW_DATA_CST);
- 	TREE_TYPE (val) = integer_type_node;
- 	RAW_DATA_LENGTH (val) = i;
-@@ -6633,13 +6630,6 @@ c_parser_initval (c_parser *parser, struct c_expr *after,
- 	init.original_type = integer_type_node;
- 	init.m_decimal = 0;
- 	process_init_element (loc, init, false, braced_init_obstack);
--	if (last)
--	  {
--	    init.value = build_int_cst (integer_type_node, lastc);
--	    init.original_code = INTEGER_CST;
--	    set_c_expr_source_range (&init, prev_loc, prev_loc);
--	    process_init_element (prev_loc, init, false, braced_init_obstack);
--	  }
-       }
- }
- 
-diff --git a/gcc/testsuite/c-c++-common/init-5.c b/gcc/testsuite/c-c++-common/init-5.c
-new file mode 100644
-index 000000000000..61b6cdb97e2f
---- /dev/null
-+++ b/gcc/testsuite/c-c++-common/init-5.c
-@@ -0,0 +1,19 @@
-+/* PR c/117190 */
-+/* { dg-do run } */
-+/* { dg-options "-O2" } */
-+
-+struct S { char d[]; } v = {
-+{ 8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-+  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-+  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-+  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-+  0, }
-+};
-+
-+int
-+main ()
-+{
-+  for (int i = 0; i < 65; ++i)
-+    if (v.d[i] != (i == 0 ? 8 : 0))
-+      __builtin_abort ();
-+}
--- 
-2.47.0
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-28  8:09 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-28  8:09 UTC (permalink / raw
  To: gentoo-commits
commit:     a7fcb7ce0f8bf2b60e3988d30acb999eb4eb03d3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 28 08:09:04 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Oct 28 08:09:04 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=a7fcb7ce
15.0.0: cut patchset 20
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index bc7c1e6..92e1e14 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-20	????
+20	28 October 2024
 
 	- 73_all_PR117190-Revert-c-Fix-up-speed-up-compilation-of-large-char-a.patch
 	- 74_all_PR117190-Revert-c-Speed-up-compilation-of-large-char-array-in.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-28 21:32 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-28 21:32 UTC (permalink / raw
  To: gentoo-commits
commit:     a0691e3578dcab1c745e963bb4f9ffe2a3889cf3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 28 21:32:18 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Oct 28 21:32:18 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=a0691e35
15.0.0: add 72_all_PR117313-linux.patch
Bug: https://gcc.gnu.org/PR117313
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117313-linux.patch | 104 ++++++++++++++++++++++++++++++
 1 file changed, 104 insertions(+)
diff --git a/15.0.0/gentoo/72_all_PR117313-linux.patch b/15.0.0/gentoo/72_all_PR117313-linux.patch
new file mode 100644
index 0000000..c8cb2e8
--- /dev/null
+++ b/15.0.0/gentoo/72_all_PR117313-linux.patch
@@ -0,0 +1,104 @@
+2024-10-28  Jakub Jelinek  <jakub@redhat.com>
+
+	PR c/117313
+gcc/c-family/
+	* c-common.cc (complete_array_type): For RAW_DATA_CST elements
+	advance curindex by RAW_DATA_LENGTH or one less than that if
+	ce->index is non-NULL.  Handle even the first element if
+	it is RAW_DATA_CST.  Formatting fix.
+gcc/testsuite/
+	* c-c++-common/init-6.c: New test.
+
+--- a/gcc/c-family/c-common.cc	2024-10-27 16:39:55.090871381 +0100
++++ b/gcc/c-family/c-common.cc	2024-10-28 12:30:01.215814079 +0100
+@@ -7044,7 +7044,8 @@ complete_array_type (tree *ptype, tree i
+ 	{
+ 	  int eltsize
+ 	    = int_size_in_bytes (TREE_TYPE (TREE_TYPE (initial_value)));
+-	  maxindex = size_int (TREE_STRING_LENGTH (initial_value)/eltsize - 1);
++	  maxindex = size_int (TREE_STRING_LENGTH (initial_value) / eltsize
++			       - 1);
+ 	}
+       else if (TREE_CODE (initial_value) == CONSTRUCTOR)
+ 	{
+@@ -7059,23 +7060,25 @@ complete_array_type (tree *ptype, tree i
+ 	  else
+ 	    {
+ 	      tree curindex;
+-	      unsigned HOST_WIDE_INT cnt;
++	      unsigned HOST_WIDE_INT cnt = 1;
+ 	      constructor_elt *ce;
+ 	      bool fold_p = false;
+ 
+ 	      if ((*v)[0].index)
+ 		maxindex = (*v)[0].index, fold_p = true;
++	      if (TREE_CODE ((*v)[0].value) == RAW_DATA_CST)
++		cnt = 0;
+ 
+ 	      curindex = maxindex;
+ 
+-	      for (cnt = 1; vec_safe_iterate (v, cnt, &ce); cnt++)
++	      for (; vec_safe_iterate (v, cnt, &ce); cnt++)
+ 		{
+ 		  bool curfold_p = false;
+ 		  if (ce->index)
+ 		    curindex = ce->index, curfold_p = true;
+-		  else
++		  if (!ce->index || TREE_CODE (ce->value) == RAW_DATA_CST)
+ 		    {
+-		      if (fold_p)
++		      if (fold_p || curfold_p)
+ 			{
+ 			  /* Since we treat size types now as ordinary
+ 			     unsigned types, we need an explicit overflow
+@@ -7083,9 +7086,16 @@ complete_array_type (tree *ptype, tree i
+ 			  tree orig = curindex;
+ 		          curindex = fold_convert (sizetype, curindex);
+ 			  overflow_p |= tree_int_cst_lt (curindex, orig);
++			  curfold_p = false;
+ 			}
+-		      curindex = size_binop (PLUS_EXPR, curindex,
+-					     size_one_node);
++		      if (TREE_CODE (ce->value) == RAW_DATA_CST)
++			curindex
++			  = size_binop (PLUS_EXPR, curindex,
++					size_int (RAW_DATA_LENGTH (ce->value)
++						  - (ce->index ? 1 : 0)));
++		      else
++			curindex = size_binop (PLUS_EXPR, curindex,
++					       size_one_node);
+ 		    }
+ 		  if (tree_int_cst_lt (maxindex, curindex))
+ 		    maxindex = curindex, fold_p = curfold_p;
+--- a/gcc/testsuite/c-c++-common/init-6.c	2024-10-28 12:35:59.526803017 +0100
++++ b/gcc/testsuite/c-c++-common/init-6.c	2024-10-28 12:35:50.394930729 +0100
+@@ -0,0 +1,29 @@
++/* PR c/117313 */
++/* { dg-do compile } */
++/* { dg-options "-O2" } */
++
++struct S { unsigned a; const unsigned char b[]; };
++struct S s = {
++  1,
++  { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x7e, 0x81, 0xa5,
++    0x81, 0xbd, 0x99, 0x81, 0x7e, 0x7e, 0xff, 0xdb, 0xff, 0xc3, 0xe7,
++    0xff, 0x7e, 0x6c, 0xfe, 0xfe, 0xfe, 0x7c, 0x38, 0x10, 0x00, 0x10,
++    0x38, 0x00, 0x00, 0x38, 0x6c, 0x6c, 0x38, 0x00, 0x00, 0x00, 0x00,
++    0x00, 0x00, 0x00, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
++    0x18, 0x00, 0x00, 0x00, 0x00, 0x0c, 0x0c, 0x0c, 0xec, 0x6c, 0x3c,
++  }
++};
++struct S t = {
++  2,
++  { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x7e, 0x81, 0xa5,
++    0x81, 0xbd, 0x99, 0x81, 0x7e, 0x7e, 0xff, 0xdb, 0xff, 0xc3, 0xe7,
++    0xff, 0x7e, 0x6c, 0xfe, 0xfe, 0xfe, 0x7c, 0x38, 0x10, 0x00, 0x10,
++    0x38, 0x00, 0x00, 0x38, 0x6c, 0x6c, 0x38, 0x00, 0x00, 0x00, 0x00,
++    0x00, 0x00, 0x00, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
++    0x18, 0x00, 0x00, 0x00, 0x00, 0x0c, 0x0c, 0x0c, 0xec, 0x6c, 0x3c,
++    0xff, 0x7e, 0x6c, 0xfe, 0xfe, 0xfe, 0x7c, 0x38, 0x10, 0x00, 0x10,
++    0x38, 0x00, 0x00, 0x38, 0x6c, 0x6c, 0x38, 0x00, 0x00, 0x00, 0x00,
++    0x00, 0x00, 0x00, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
++    0x18, 0x00, 0x00, 0x00, 0x00, 0x0c, 0x0c, 0x0c, 0xec, 0x6c, 0x3c
++  }
++};
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-29 19:17 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-29 19:17 UTC (permalink / raw
  To: gentoo-commits
commit:     cf73522a8c586ea07421892617463fe80a3f05ae
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 29 19:17:04 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct 29 19:17:04 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=cf73522a
15.0.0: drop 72_all_PR117313-linux.patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117313-linux.patch | 104 ------------------------------
 1 file changed, 104 deletions(-)
diff --git a/15.0.0/gentoo/72_all_PR117313-linux.patch b/15.0.0/gentoo/72_all_PR117313-linux.patch
deleted file mode 100644
index c8cb2e8..0000000
--- a/15.0.0/gentoo/72_all_PR117313-linux.patch
+++ /dev/null
@@ -1,104 +0,0 @@
-2024-10-28  Jakub Jelinek  <jakub@redhat.com>
-
-	PR c/117313
-gcc/c-family/
-	* c-common.cc (complete_array_type): For RAW_DATA_CST elements
-	advance curindex by RAW_DATA_LENGTH or one less than that if
-	ce->index is non-NULL.  Handle even the first element if
-	it is RAW_DATA_CST.  Formatting fix.
-gcc/testsuite/
-	* c-c++-common/init-6.c: New test.
-
---- a/gcc/c-family/c-common.cc	2024-10-27 16:39:55.090871381 +0100
-+++ b/gcc/c-family/c-common.cc	2024-10-28 12:30:01.215814079 +0100
-@@ -7044,7 +7044,8 @@ complete_array_type (tree *ptype, tree i
- 	{
- 	  int eltsize
- 	    = int_size_in_bytes (TREE_TYPE (TREE_TYPE (initial_value)));
--	  maxindex = size_int (TREE_STRING_LENGTH (initial_value)/eltsize - 1);
-+	  maxindex = size_int (TREE_STRING_LENGTH (initial_value) / eltsize
-+			       - 1);
- 	}
-       else if (TREE_CODE (initial_value) == CONSTRUCTOR)
- 	{
-@@ -7059,23 +7060,25 @@ complete_array_type (tree *ptype, tree i
- 	  else
- 	    {
- 	      tree curindex;
--	      unsigned HOST_WIDE_INT cnt;
-+	      unsigned HOST_WIDE_INT cnt = 1;
- 	      constructor_elt *ce;
- 	      bool fold_p = false;
- 
- 	      if ((*v)[0].index)
- 		maxindex = (*v)[0].index, fold_p = true;
-+	      if (TREE_CODE ((*v)[0].value) == RAW_DATA_CST)
-+		cnt = 0;
- 
- 	      curindex = maxindex;
- 
--	      for (cnt = 1; vec_safe_iterate (v, cnt, &ce); cnt++)
-+	      for (; vec_safe_iterate (v, cnt, &ce); cnt++)
- 		{
- 		  bool curfold_p = false;
- 		  if (ce->index)
- 		    curindex = ce->index, curfold_p = true;
--		  else
-+		  if (!ce->index || TREE_CODE (ce->value) == RAW_DATA_CST)
- 		    {
--		      if (fold_p)
-+		      if (fold_p || curfold_p)
- 			{
- 			  /* Since we treat size types now as ordinary
- 			     unsigned types, we need an explicit overflow
-@@ -7083,9 +7086,16 @@ complete_array_type (tree *ptype, tree i
- 			  tree orig = curindex;
- 		          curindex = fold_convert (sizetype, curindex);
- 			  overflow_p |= tree_int_cst_lt (curindex, orig);
-+			  curfold_p = false;
- 			}
--		      curindex = size_binop (PLUS_EXPR, curindex,
--					     size_one_node);
-+		      if (TREE_CODE (ce->value) == RAW_DATA_CST)
-+			curindex
-+			  = size_binop (PLUS_EXPR, curindex,
-+					size_int (RAW_DATA_LENGTH (ce->value)
-+						  - (ce->index ? 1 : 0)));
-+		      else
-+			curindex = size_binop (PLUS_EXPR, curindex,
-+					       size_one_node);
- 		    }
- 		  if (tree_int_cst_lt (maxindex, curindex))
- 		    maxindex = curindex, fold_p = curfold_p;
---- a/gcc/testsuite/c-c++-common/init-6.c	2024-10-28 12:35:59.526803017 +0100
-+++ b/gcc/testsuite/c-c++-common/init-6.c	2024-10-28 12:35:50.394930729 +0100
-@@ -0,0 +1,29 @@
-+/* PR c/117313 */
-+/* { dg-do compile } */
-+/* { dg-options "-O2" } */
-+
-+struct S { unsigned a; const unsigned char b[]; };
-+struct S s = {
-+  1,
-+  { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x7e, 0x81, 0xa5,
-+    0x81, 0xbd, 0x99, 0x81, 0x7e, 0x7e, 0xff, 0xdb, 0xff, 0xc3, 0xe7,
-+    0xff, 0x7e, 0x6c, 0xfe, 0xfe, 0xfe, 0x7c, 0x38, 0x10, 0x00, 0x10,
-+    0x38, 0x00, 0x00, 0x38, 0x6c, 0x6c, 0x38, 0x00, 0x00, 0x00, 0x00,
-+    0x00, 0x00, 0x00, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-+    0x18, 0x00, 0x00, 0x00, 0x00, 0x0c, 0x0c, 0x0c, 0xec, 0x6c, 0x3c,
-+  }
-+};
-+struct S t = {
-+  2,
-+  { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x7e, 0x81, 0xa5,
-+    0x81, 0xbd, 0x99, 0x81, 0x7e, 0x7e, 0xff, 0xdb, 0xff, 0xc3, 0xe7,
-+    0xff, 0x7e, 0x6c, 0xfe, 0xfe, 0xfe, 0x7c, 0x38, 0x10, 0x00, 0x10,
-+    0x38, 0x00, 0x00, 0x38, 0x6c, 0x6c, 0x38, 0x00, 0x00, 0x00, 0x00,
-+    0x00, 0x00, 0x00, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-+    0x18, 0x00, 0x00, 0x00, 0x00, 0x0c, 0x0c, 0x0c, 0xec, 0x6c, 0x3c,
-+    0xff, 0x7e, 0x6c, 0xfe, 0xfe, 0xfe, 0x7c, 0x38, 0x10, 0x00, 0x10,
-+    0x38, 0x00, 0x00, 0x38, 0x6c, 0x6c, 0x38, 0x00, 0x00, 0x00, 0x00,
-+    0x00, 0x00, 0x00, 0x18, 0x18, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-+    0x18, 0x00, 0x00, 0x00, 0x00, 0x0c, 0x0c, 0x0c, 0xec, 0x6c, 0x3c
-+  }
-+};
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-10-30 16:03 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-10-30 16:03 UTC (permalink / raw
  To: gentoo-commits
commit:     e644776e934d664aae0b55d6ec4230327607934e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 30 16:03:30 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Oct 30 16:03:30 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=e644776e
15.0.0: revert bad pattern causing ICE
Bug: https://gcc.gnu.org/PR117363
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117363-revert.patch | 106 +++++++++++++++++++++++++++++
 1 file changed, 106 insertions(+)
diff --git a/15.0.0/gentoo/72_all_PR117363-revert.patch b/15.0.0/gentoo/72_all_PR117363-revert.patch
new file mode 100644
index 0000000..3e5be35
--- /dev/null
+++ b/15.0.0/gentoo/72_all_PR117363-revert.patch
@@ -0,0 +1,106 @@
+From a7df875788d7303639123771af1f4238e207f442 Mon Sep 17 00:00:00 2001
+Message-ID: <a7df875788d7303639123771af1f4238e207f442.1730304104.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Wed, 30 Oct 2024 15:59:01 +0000
+Subject: [PATCH] Revert "Match: Simplify (x != 0 ? x + ~0 : 0) to (x - x !=
+ 0)."
+
+This reverts commit 4af8db3eca12b2db3753ce4b098cbd0ae32b4796.
+
+Bug: https://gcc.gnu.org/PR117363
+---
+ gcc/match.pd                               | 10 ---------
+ gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c | 26 ----------------------
+ gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c | 26 ----------------------
+ 3 files changed, 62 deletions(-)
+ delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c
+ delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c
+
+diff --git a/gcc/match.pd b/gcc/match.pd
+index c851ac56e37c..809c717bc862 100644
+--- a/gcc/match.pd
++++ b/gcc/match.pd
+@@ -3391,16 +3391,6 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
+   }
+   (if (wi::eq_p (sum, wi::uhwi (0, precision)))))))
+ 
+-/* The boundary condition for case 10: IMM = 1:
+-   SAT_U_SUB = X >= IMM ? (X - IMM) : 0.
+-   simplify (X != 0 ? X + ~0 : 0) to (X - X != 0).  */
+-(simplify
+- (cond (ne@1 @0 integer_zerop)
+-       (nop_convert? (plus (nop_convert? @0) integer_all_onesp))
+-       integer_zerop)
+- (if (INTEGRAL_TYPE_P (type))
+-   (minus @0 (convert @1))))
+-
+ /* Signed saturation sub, case 1:
+    T minus = (T)((UT)X - (UT)Y);
+    SAT_S_SUB = (X ^ Y) & (X ^ minus) < 0 ? (-(T)(X < 0) ^ MAX) : minus;
+diff --git a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c b/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c
+deleted file mode 100644
+index 962bf0954f62..000000000000
+--- a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c
++++ /dev/null
+@@ -1,26 +0,0 @@
+-/* { dg-do compile } */
+-/* { dg-options "-O2 -fdump-tree-phiopt1" } */
+-
+-#include <stdint.h>
+-
+-uint8_t f1 (uint8_t x)
+-{
+-  return x >= (uint8_t)1 ? x - (uint8_t)1 : 0;
+-}
+-
+-uint16_t f2 (uint16_t x)
+-{
+-  return x >= (uint16_t)1 ? x - (uint16_t)1 : 0;
+-}
+-
+-uint32_t f3 (uint32_t x)
+-{
+-  return x >= (uint32_t)1 ? x - (uint32_t)1 : 0;
+-}
+-
+-uint64_t f4 (uint64_t x)
+-{
+-  return x >= (uint64_t)1 ? x - (uint64_t)1 : 0;
+-}
+-
+-/* { dg-final { scan-tree-dump-not "goto" "phiopt1" } } */
+diff --git a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c b/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c
+deleted file mode 100644
+index 62a2ab631846..000000000000
+--- a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c
++++ /dev/null
+@@ -1,26 +0,0 @@
+-/* { dg-do compile } */
+-/* { dg-options "-O2 -fdump-tree-phiopt1" } */
+-
+-#include <stdint.h>
+-
+-int8_t f1 (int8_t x)
+-{
+-  return x != 0 ? x - (int8_t)1 : 0;
+-}
+-
+-int16_t f2 (int16_t x)
+-{
+-  return x != 0 ? x - (int16_t)1 : 0;
+-}
+-
+-int32_t f3 (int32_t x)
+-{
+-  return x != 0 ? x - (int32_t)1 : 0;
+-}
+-
+-int64_t f4 (int64_t x)
+-{
+-  return x != 0 ? x - (int64_t)1 : 0;
+-}
+-
+-/* { dg-final { scan-tree-dump-not "goto" "phiopt1" } } */
+-- 
+2.47.0
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-01  8:17 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-01  8:17 UTC (permalink / raw
  To: gentoo-commits
commit:     e7cf23fa4728ef5ab8ab1e0bde2c1475d91cb7ed
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Nov  1 08:17:03 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Nov  1 08:17:03 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=e7cf23fa
15.0.0: add time64 patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/31_all_time64.patch | 39 +++++++++++++++++++++++++++++++++++++++
 15.0.0/gentoo/README.history      |  4 ++++
 2 files changed, 43 insertions(+)
diff --git a/15.0.0/gentoo/31_all_time64.patch b/15.0.0/gentoo/31_all_time64.patch
new file mode 100644
index 0000000..ac972b9
--- /dev/null
+++ b/15.0.0/gentoo/31_all_time64.patch
@@ -0,0 +1,39 @@
+From b2ee3846dfcea638e0fbf2d550234f1c7594fcdb Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Micha=C5=82=20G=C3=B3rny?= <mgorny@gentoo.org>
+Date: Fri, 1 Nov 2024 07:48:37 +0100
+Subject: [PATCH] Support forcing _TIME_BITS=64 for time64 profiles
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+Support forcing _TIME_BITS=64 and _FILE_OFFSET_BITS=64
+via -D_GENTOO_TIME64_FORCE=1, for time64 profiles.
+
+Signed-off-by: Michał Górny <mgorny@gentoo.org>
+---
+ gcc/c-family/c-cppbuiltin.cc | 9 +++++++++
+ 1 file changed, 9 insertions(+)
+
+diff --git a/gcc/c-family/c-cppbuiltin.cc b/gcc/c-family/c-cppbuiltin.cc
+index 8bbfe84b2..962cbd414 100644
+--- a/gcc/c-family/c-cppbuiltin.cc
++++ b/gcc/c-family/c-cppbuiltin.cc
+@@ -1593,6 +1593,15 @@ c_cpp_builtins (cpp_reader *pfile)
+     builtin_define_with_int_value ("_FORTIFY_SOURCE", GENTOO_FORTIFY_SOURCE_LEVEL);
+ #endif
+ 
++#ifndef _GENTOO_TIME64_FORCE
++  #define _GENTOO_TIME64_FORCE 0
++#endif
++
++  if (_GENTOO_TIME64_FORCE) {
++    cpp_define (pfile, "_FILE_OFFSET_BITS=64");
++    cpp_define (pfile, "_TIME_BITS=64");
++  }
++
+   /* Misc.  */
+   if (flag_gnu89_inline)
+     cpp_define (pfile, "__GNUC_GNU_INLINE__");
+-- 
+2.47.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 92e1e14..39a708d 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+21	????
+
+	+ 31_all_time64.patch	
+
 20	28 October 2024
 
 	- 73_all_PR117190-Revert-c-Fix-up-speed-up-compilation-of-large-char-a.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-01  8:18 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-01  8:18 UTC (permalink / raw
  To: gentoo-commits
commit:     0460c30910a6114b6ad106633bad7a0a25b87535
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Nov  1 08:18:28 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Nov  1 08:18:28 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=0460c309
15.00.: cut patchset 21
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 39a708d..2d6aaf8 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-21	????
+21	1 November 2024
 
 	+ 31_all_time64.patch	
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-01  8:24 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-01  8:24 UTC (permalink / raw
  To: gentoo-commits
commit:     5c6f5f3e37e314c90dc54d7e04483378df7a558e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Nov  1 08:23:59 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Nov  1 08:24:06 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=5c6f5f3e
Revert "15.0.0: respin patchset 2 to drop 72 revert patch"
This reverts commit 1da292bbeff6151ecb983ee5552d6ab8305bb4e7.
Still needed for live. Already spun 21 so we can onw put this back.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117363-revert.patch | 106 +++++++++++++++++++++++++++++
 1 file changed, 106 insertions(+)
diff --git a/15.0.0/gentoo/72_all_PR117363-revert.patch b/15.0.0/gentoo/72_all_PR117363-revert.patch
new file mode 100644
index 0000000..3e5be35
--- /dev/null
+++ b/15.0.0/gentoo/72_all_PR117363-revert.patch
@@ -0,0 +1,106 @@
+From a7df875788d7303639123771af1f4238e207f442 Mon Sep 17 00:00:00 2001
+Message-ID: <a7df875788d7303639123771af1f4238e207f442.1730304104.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Wed, 30 Oct 2024 15:59:01 +0000
+Subject: [PATCH] Revert "Match: Simplify (x != 0 ? x + ~0 : 0) to (x - x !=
+ 0)."
+
+This reverts commit 4af8db3eca12b2db3753ce4b098cbd0ae32b4796.
+
+Bug: https://gcc.gnu.org/PR117363
+---
+ gcc/match.pd                               | 10 ---------
+ gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c | 26 ----------------------
+ gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c | 26 ----------------------
+ 3 files changed, 62 deletions(-)
+ delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c
+ delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c
+
+diff --git a/gcc/match.pd b/gcc/match.pd
+index c851ac56e37c..809c717bc862 100644
+--- a/gcc/match.pd
++++ b/gcc/match.pd
+@@ -3391,16 +3391,6 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
+   }
+   (if (wi::eq_p (sum, wi::uhwi (0, precision)))))))
+ 
+-/* The boundary condition for case 10: IMM = 1:
+-   SAT_U_SUB = X >= IMM ? (X - IMM) : 0.
+-   simplify (X != 0 ? X + ~0 : 0) to (X - X != 0).  */
+-(simplify
+- (cond (ne@1 @0 integer_zerop)
+-       (nop_convert? (plus (nop_convert? @0) integer_all_onesp))
+-       integer_zerop)
+- (if (INTEGRAL_TYPE_P (type))
+-   (minus @0 (convert @1))))
+-
+ /* Signed saturation sub, case 1:
+    T minus = (T)((UT)X - (UT)Y);
+    SAT_S_SUB = (X ^ Y) & (X ^ minus) < 0 ? (-(T)(X < 0) ^ MAX) : minus;
+diff --git a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c b/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c
+deleted file mode 100644
+index 962bf0954f62..000000000000
+--- a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c
++++ /dev/null
+@@ -1,26 +0,0 @@
+-/* { dg-do compile } */
+-/* { dg-options "-O2 -fdump-tree-phiopt1" } */
+-
+-#include <stdint.h>
+-
+-uint8_t f1 (uint8_t x)
+-{
+-  return x >= (uint8_t)1 ? x - (uint8_t)1 : 0;
+-}
+-
+-uint16_t f2 (uint16_t x)
+-{
+-  return x >= (uint16_t)1 ? x - (uint16_t)1 : 0;
+-}
+-
+-uint32_t f3 (uint32_t x)
+-{
+-  return x >= (uint32_t)1 ? x - (uint32_t)1 : 0;
+-}
+-
+-uint64_t f4 (uint64_t x)
+-{
+-  return x >= (uint64_t)1 ? x - (uint64_t)1 : 0;
+-}
+-
+-/* { dg-final { scan-tree-dump-not "goto" "phiopt1" } } */
+diff --git a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c b/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c
+deleted file mode 100644
+index 62a2ab631846..000000000000
+--- a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c
++++ /dev/null
+@@ -1,26 +0,0 @@
+-/* { dg-do compile } */
+-/* { dg-options "-O2 -fdump-tree-phiopt1" } */
+-
+-#include <stdint.h>
+-
+-int8_t f1 (int8_t x)
+-{
+-  return x != 0 ? x - (int8_t)1 : 0;
+-}
+-
+-int16_t f2 (int16_t x)
+-{
+-  return x != 0 ? x - (int16_t)1 : 0;
+-}
+-
+-int32_t f3 (int32_t x)
+-{
+-  return x != 0 ? x - (int32_t)1 : 0;
+-}
+-
+-int64_t f4 (int64_t x)
+-{
+-  return x != 0 ? x - (int64_t)1 : 0;
+-}
+-
+-/* { dg-final { scan-tree-dump-not "goto" "phiopt1" } } */
+-- 
+2.47.0
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-01  8:24 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-01  8:24 UTC (permalink / raw
  To: gentoo-commits
commit:     1da292bbeff6151ecb983ee5552d6ab8305bb4e7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Nov  1 08:21:55 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Nov  1 08:21:55 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=1da292bb
15.0.0: respin patchset 2 to drop 72 revert patch
That didn't land in the last snapshot, oops.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117363-revert.patch | 106 -----------------------------
 1 file changed, 106 deletions(-)
diff --git a/15.0.0/gentoo/72_all_PR117363-revert.patch b/15.0.0/gentoo/72_all_PR117363-revert.patch
deleted file mode 100644
index 3e5be35..0000000
--- a/15.0.0/gentoo/72_all_PR117363-revert.patch
+++ /dev/null
@@ -1,106 +0,0 @@
-From a7df875788d7303639123771af1f4238e207f442 Mon Sep 17 00:00:00 2001
-Message-ID: <a7df875788d7303639123771af1f4238e207f442.1730304104.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Wed, 30 Oct 2024 15:59:01 +0000
-Subject: [PATCH] Revert "Match: Simplify (x != 0 ? x + ~0 : 0) to (x - x !=
- 0)."
-
-This reverts commit 4af8db3eca12b2db3753ce4b098cbd0ae32b4796.
-
-Bug: https://gcc.gnu.org/PR117363
----
- gcc/match.pd                               | 10 ---------
- gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c | 26 ----------------------
- gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c | 26 ----------------------
- 3 files changed, 62 deletions(-)
- delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c
- delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c
-
-diff --git a/gcc/match.pd b/gcc/match.pd
-index c851ac56e37c..809c717bc862 100644
---- a/gcc/match.pd
-+++ b/gcc/match.pd
-@@ -3391,16 +3391,6 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
-   }
-   (if (wi::eq_p (sum, wi::uhwi (0, precision)))))))
- 
--/* The boundary condition for case 10: IMM = 1:
--   SAT_U_SUB = X >= IMM ? (X - IMM) : 0.
--   simplify (X != 0 ? X + ~0 : 0) to (X - X != 0).  */
--(simplify
-- (cond (ne@1 @0 integer_zerop)
--       (nop_convert? (plus (nop_convert? @0) integer_all_onesp))
--       integer_zerop)
-- (if (INTEGRAL_TYPE_P (type))
--   (minus @0 (convert @1))))
--
- /* Signed saturation sub, case 1:
-    T minus = (T)((UT)X - (UT)Y);
-    SAT_S_SUB = (X ^ Y) & (X ^ minus) < 0 ? (-(T)(X < 0) ^ MAX) : minus;
-diff --git a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c b/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c
-deleted file mode 100644
-index 962bf0954f62..000000000000
---- a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c
-+++ /dev/null
-@@ -1,26 +0,0 @@
--/* { dg-do compile } */
--/* { dg-options "-O2 -fdump-tree-phiopt1" } */
--
--#include <stdint.h>
--
--uint8_t f1 (uint8_t x)
--{
--  return x >= (uint8_t)1 ? x - (uint8_t)1 : 0;
--}
--
--uint16_t f2 (uint16_t x)
--{
--  return x >= (uint16_t)1 ? x - (uint16_t)1 : 0;
--}
--
--uint32_t f3 (uint32_t x)
--{
--  return x >= (uint32_t)1 ? x - (uint32_t)1 : 0;
--}
--
--uint64_t f4 (uint64_t x)
--{
--  return x >= (uint64_t)1 ? x - (uint64_t)1 : 0;
--}
--
--/* { dg-final { scan-tree-dump-not "goto" "phiopt1" } } */
-diff --git a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c b/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c
-deleted file mode 100644
-index 62a2ab631846..000000000000
---- a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c
-+++ /dev/null
-@@ -1,26 +0,0 @@
--/* { dg-do compile } */
--/* { dg-options "-O2 -fdump-tree-phiopt1" } */
--
--#include <stdint.h>
--
--int8_t f1 (int8_t x)
--{
--  return x != 0 ? x - (int8_t)1 : 0;
--}
--
--int16_t f2 (int16_t x)
--{
--  return x != 0 ? x - (int16_t)1 : 0;
--}
--
--int32_t f3 (int32_t x)
--{
--  return x != 0 ? x - (int32_t)1 : 0;
--}
--
--int64_t f4 (int64_t x)
--{
--  return x != 0 ? x - (int64_t)1 : 0;
--}
--
--/* { dg-final { scan-tree-dump-not "goto" "phiopt1" } } */
--- 
-2.47.0
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-03 23:16 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-03 23:16 UTC (permalink / raw
  To: gentoo-commits
commit:     4857e834cefe40cf6c07def1aa9eac45d0021653
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Nov  3 23:15:59 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Nov  3 23:16:09 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=4857e834
15.0.0: drop 72_all_PR117363-revert.patch
Fixed upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117363-revert.patch | 106 -----------------------------
 1 file changed, 106 deletions(-)
diff --git a/15.0.0/gentoo/72_all_PR117363-revert.patch b/15.0.0/gentoo/72_all_PR117363-revert.patch
deleted file mode 100644
index 3e5be35..0000000
--- a/15.0.0/gentoo/72_all_PR117363-revert.patch
+++ /dev/null
@@ -1,106 +0,0 @@
-From a7df875788d7303639123771af1f4238e207f442 Mon Sep 17 00:00:00 2001
-Message-ID: <a7df875788d7303639123771af1f4238e207f442.1730304104.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Wed, 30 Oct 2024 15:59:01 +0000
-Subject: [PATCH] Revert "Match: Simplify (x != 0 ? x + ~0 : 0) to (x - x !=
- 0)."
-
-This reverts commit 4af8db3eca12b2db3753ce4b098cbd0ae32b4796.
-
-Bug: https://gcc.gnu.org/PR117363
----
- gcc/match.pd                               | 10 ---------
- gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c | 26 ----------------------
- gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c | 26 ----------------------
- 3 files changed, 62 deletions(-)
- delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c
- delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c
-
-diff --git a/gcc/match.pd b/gcc/match.pd
-index c851ac56e37c..809c717bc862 100644
---- a/gcc/match.pd
-+++ b/gcc/match.pd
-@@ -3391,16 +3391,6 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
-   }
-   (if (wi::eq_p (sum, wi::uhwi (0, precision)))))))
- 
--/* The boundary condition for case 10: IMM = 1:
--   SAT_U_SUB = X >= IMM ? (X - IMM) : 0.
--   simplify (X != 0 ? X + ~0 : 0) to (X - X != 0).  */
--(simplify
-- (cond (ne@1 @0 integer_zerop)
--       (nop_convert? (plus (nop_convert? @0) integer_all_onesp))
--       integer_zerop)
-- (if (INTEGRAL_TYPE_P (type))
--   (minus @0 (convert @1))))
--
- /* Signed saturation sub, case 1:
-    T minus = (T)((UT)X - (UT)Y);
-    SAT_S_SUB = (X ^ Y) & (X ^ minus) < 0 ? (-(T)(X < 0) ^ MAX) : minus;
-diff --git a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c b/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c
-deleted file mode 100644
-index 962bf0954f62..000000000000
---- a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-44.c
-+++ /dev/null
-@@ -1,26 +0,0 @@
--/* { dg-do compile } */
--/* { dg-options "-O2 -fdump-tree-phiopt1" } */
--
--#include <stdint.h>
--
--uint8_t f1 (uint8_t x)
--{
--  return x >= (uint8_t)1 ? x - (uint8_t)1 : 0;
--}
--
--uint16_t f2 (uint16_t x)
--{
--  return x >= (uint16_t)1 ? x - (uint16_t)1 : 0;
--}
--
--uint32_t f3 (uint32_t x)
--{
--  return x >= (uint32_t)1 ? x - (uint32_t)1 : 0;
--}
--
--uint64_t f4 (uint64_t x)
--{
--  return x >= (uint64_t)1 ? x - (uint64_t)1 : 0;
--}
--
--/* { dg-final { scan-tree-dump-not "goto" "phiopt1" } } */
-diff --git a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c b/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c
-deleted file mode 100644
-index 62a2ab631846..000000000000
---- a/gcc/testsuite/gcc.dg/tree-ssa/phi-opt-45.c
-+++ /dev/null
-@@ -1,26 +0,0 @@
--/* { dg-do compile } */
--/* { dg-options "-O2 -fdump-tree-phiopt1" } */
--
--#include <stdint.h>
--
--int8_t f1 (int8_t x)
--{
--  return x != 0 ? x - (int8_t)1 : 0;
--}
--
--int16_t f2 (int16_t x)
--{
--  return x != 0 ? x - (int16_t)1 : 0;
--}
--
--int32_t f3 (int32_t x)
--{
--  return x != 0 ? x - (int32_t)1 : 0;
--}
--
--int64_t f4 (int64_t x)
--{
--  return x != 0 ? x - (int64_t)1 : 0;
--}
--
--/* { dg-final { scan-tree-dump-not "goto" "phiopt1" } } */
--- 
-2.47.0
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-07 16:13 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-07 16:13 UTC (permalink / raw
  To: gentoo-commits
commit:     5f55e0a35a6595391420057c748c94110a41cacd
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Nov  7 16:13:27 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Nov  7 16:13:27 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=5f55e0a3
15.0.0: add 72_all_PR117476-revert.patch
Bug: https://gcc.gnu.org/PR117476
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117476-revert.patch | 74 ++++++++++++++++++++++++++++++
 1 file changed, 74 insertions(+)
diff --git a/15.0.0/gentoo/72_all_PR117476-revert.patch b/15.0.0/gentoo/72_all_PR117476-revert.patch
new file mode 100644
index 0000000..c073213
--- /dev/null
+++ b/15.0.0/gentoo/72_all_PR117476-revert.patch
@@ -0,0 +1,74 @@
+From 7f98f96e02bd3b5cac35655d933382f9225fef59 Mon Sep 17 00:00:00 2001
+Message-ID: <7f98f96e02bd3b5cac35655d933382f9225fef59.1730995976.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Thu, 7 Nov 2024 16:12:40 +0000
+Subject: [PATCH] Revert "[PATCH v2] RISC-V: zero_extend(not) -> xor
+ optimization [PR112398]"
+
+This reverts commit 69bd93c167fefbdff0cb88614275358b7a2b2941.
+
+Bug: https://gcc.gnu.org/PR117476
+---
+ gcc/simplify-rtx.cc                       | 22 ----------------------
+ gcc/testsuite/gcc.target/riscv/pr112398.c | 14 --------------
+ 2 files changed, 36 deletions(-)
+ delete mode 100644 gcc/testsuite/gcc.target/riscv/pr112398.c
+
+diff --git a/gcc/simplify-rtx.cc b/gcc/simplify-rtx.cc
+index d05efac20dc8..893c5f6e1ae0 100644
+--- a/gcc/simplify-rtx.cc
++++ b/gcc/simplify-rtx.cc
+@@ -1842,28 +1842,6 @@ simplify_context::simplify_unary_operation_1 (rtx_code code, machine_mode mode,
+ 	      & ~GET_MODE_MASK (op_mode)) == 0)
+ 	return SUBREG_REG (op);
+ 
+-      /* Trying to optimize:
+-	 (zero_extend:M (subreg:N (not:M (X:M)))) ->
+-	 (xor:M (zero_extend:M (subreg:N (X:M)), mask))
+-	 where the mask is GET_MODE_MASK (N).
+-	 For the cases when X:M doesn't have any non-zero bits
+-	 outside of mode N, (zero_extend:M (subreg:N (X:M))
+-	 will be simplified to just (X:M)
+-	 and whole optimization will be -> (xor:M (X:M, mask)).  */
+-      if (SUBREG_P (op)
+-	  && GET_CODE (XEXP (op, 0)) == NOT
+-	  && GET_MODE (XEXP (op, 0)) == mode
+-	  && subreg_lowpart_p (op)
+-	  && GET_MODE_SIZE (GET_MODE (op)).is_constant ()
+-	  && (nonzero_bits (XEXP (XEXP (op, 0), 0), mode)
+-	      & ~GET_MODE_MASK (mode)) == 0)
+-      {
+-	const uint64_t mask = GET_MODE_MASK (GET_MODE (op));
+-	return simplify_gen_binary (XOR, mode,
+-				    XEXP (XEXP (op, 0), 0),
+-				    gen_int_mode (mask, mode));
+-      }
+-
+ #if defined(POINTERS_EXTEND_UNSIGNED)
+       /* As we do not know which address space the pointer is referring to,
+ 	 we can do this only if the target does not support different pointer
+diff --git a/gcc/testsuite/gcc.target/riscv/pr112398.c b/gcc/testsuite/gcc.target/riscv/pr112398.c
+deleted file mode 100644
+index 624a665b76c9..000000000000
+--- a/gcc/testsuite/gcc.target/riscv/pr112398.c
++++ /dev/null
+@@ -1,14 +0,0 @@
+-/* { dg-do compile } */
+-/* { dg-options "-march=rv64gc -mabi=lp64d" } */
+-/* { dg-skip-if "" { *-*-* } { "-O0" "-Og" } } */
+-
+-#include <stdint.h>
+-
+-uint8_t neg_u8 (const uint8_t src)
+-{
+-  return ~src;
+-}
+-
+-/* { dg-final { scan-assembler-times "xori\t" 1 } } */
+-/* { dg-final { scan-assembler-not "not\t" } } */
+-/* { dg-final { scan-assembler-not "andi\t" } } */
+
+base-commit: 6a6b8b847bce78a909379f3b9d3365c4ac4f0ff5
+-- 
+2.47.0
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-08  8:22 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-08  8:22 UTC (permalink / raw
  To: gentoo-commits
commit:     d233b7b4ed5b56b7f0291ae3c59c9d6f84120692
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Nov  8 08:22:01 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Nov  8 08:22:40 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=d233b7b4
15.0.0: add workaround for recursion in sccvn
Bug: https://gcc.gnu.org/PR117493
Bug: https://gcc.gnu.org/PR117496
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...93-sccvn-insert_predicates_for_cond-limit.patch | 41 ++++++++++++++++++++++
 1 file changed, 41 insertions(+)
diff --git a/15.0.0/gentoo/73_all_PR117493-sccvn-insert_predicates_for_cond-limit.patch b/15.0.0/gentoo/73_all_PR117493-sccvn-insert_predicates_for_cond-limit.patch
new file mode 100644
index 0000000..2000754
--- /dev/null
+++ b/15.0.0/gentoo/73_all_PR117493-sccvn-insert_predicates_for_cond-limit.patch
@@ -0,0 +1,41 @@
+https://gcc.gnu.org/PR117493
+https://gcc.gnu.org/PR117496
+
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=117493#c5
+--- a/gcc/tree-ssa-sccvn.cc
++++ b/gcc/tree-ssa-sccvn.cc
+@@ -7902,8 +7902,11 @@ insert_related_predicates_on_edge (enum tree_code code, tree *ops, edge pred_e)
+    derived from LHS CODE RHS.  */
+ static void
+ insert_predicates_for_cond (tree_code code, tree lhs, tree rhs,
+-			    edge true_e, edge false_e)
++			    edge true_e, edge false_e, int n = 0)
+ {
++  if (n > 5)
++    return;
++
+   /* If both edges are null, then there is nothing to be done. */
+   if (!true_e && !false_e)
+     return;
+@@ -7964,7 +7967,7 @@ insert_predicates_for_cond (tree_code code, tree lhs, tree rhs,
+ 	    edge nf = false_e;
+ 	    if (code == EQ_EXPR)
+ 	      std::swap (nt, nf);
+-	    insert_predicates_for_cond (nc, nlhs, nrhs, nt, nf);
++	    insert_predicates_for_cond (nc, nlhs, nrhs, nt, nf, n + 1);
+ 	  }
+       /* (a | b) == 0 ->
+ 	    on true edge assert: a == 0 & b == 0. */
+@@ -7977,10 +7980,10 @@ insert_predicates_for_cond (tree_code code, tree lhs, tree rhs,
+ 	  tree nlhs;
+ 
+ 	  nlhs = vn_valueize (gimple_assign_rhs1 (def_stmt));
+-	  insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr);
++	  insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr, n + 1);
+ 
+ 	  nlhs = vn_valueize (gimple_assign_rhs2 (def_stmt));
+-	  insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr);
++	  insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr, n + 1);
+ 	}
+     }
+ }
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-09  7:55 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-09  7:55 UTC (permalink / raw
  To: gentoo-commits
commit:     a6cc1808601268d37a0c43ad67b5c116d9678c4d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Nov  9 07:55:37 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Nov  9 07:55:37 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=a6cc1808
15.0.0: update 73_all_PR117493-sccvn-insert_predicates_for_cond-limit.patch
This version will be committed shortly.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...93-sccvn-insert_predicates_for_cond-limit.patch | 107 ++++++++++++++++-----
 1 file changed, 82 insertions(+), 25 deletions(-)
diff --git a/15.0.0/gentoo/73_all_PR117493-sccvn-insert_predicates_for_cond-limit.patch b/15.0.0/gentoo/73_all_PR117493-sccvn-insert_predicates_for_cond-limit.patch
index 2000754..9816e52 100644
--- a/15.0.0/gentoo/73_all_PR117493-sccvn-insert_predicates_for_cond-limit.patch
+++ b/15.0.0/gentoo/73_all_PR117493-sccvn-insert_predicates_for_cond-limit.patch
@@ -1,41 +1,98 @@
-https://gcc.gnu.org/PR117493
-https://gcc.gnu.org/PR117496
+From a49a60790ae2032dfeee617ba9488fc80e09b3a8 Mon Sep 17 00:00:00 2001
+Message-ID: <a49a60790ae2032dfeee617ba9488fc80e09b3a8.1731138919.git.sam@gentoo.org>
+From: Andrew Pinski <quic_apinski@quicinc.com>
+Date: Fri, 8 Nov 2024 17:35:02 -0800
+Subject: [PATCH] VN: Don't recurse on for the same value of `a | b` [PR117496]
 
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=117493#c5
+After adding vn_valueize to the handle the `a | b ==/!= 0` case
+of insert_predicates_for_cond, it would go into an infinite loop
+as the Value number for either a or b could be the same as what it
+is for the whole expression. This avoids that recursion so there is
+no infinite loop here.
+
+Bootstrapped and tested on x86_64-linux.
+
+	PR tree-optimization/117496
+
+gcc/ChangeLog:
+
+	* tree-ssa-sccvn.cc (insert_predicates_for_cond): If the
+	valueization for the new lhs is the same as the old one,
+	don't recurse.
+
+gcc/testsuite/ChangeLog:
+
+	* gcc.dg/torture/pr117496-1.c: New test.
+
+Signed-off-by: Andrew Pinski <quic_apinski@quicinc.com>
+---
+ gcc/testsuite/gcc.dg/torture/pr117496-1.c | 25 +++++++++++++++++++++++
+ gcc/tree-ssa-sccvn.cc                     | 11 ++++++++--
+ 2 files changed, 34 insertions(+), 2 deletions(-)
+ create mode 100644 gcc/testsuite/gcc.dg/torture/pr117496-1.c
+
+diff --git a/gcc/testsuite/gcc.dg/torture/pr117496-1.c b/gcc/testsuite/gcc.dg/torture/pr117496-1.c
+new file mode 100644
+index 000000000000..f35d13dfa85d
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/torture/pr117496-1.c
+@@ -0,0 +1,25 @@
++/* { dg-do compile } */
++
++
++/* PR tree-optimization/117496 */
++/* This would go into an infinite loop into VN while recording
++   the predicates for the `tracks == 0 && wm == 0` GIMPLE_COND.
++   As wm_N and tracks_N would valueize back to `tracks | wm`.  */
++
++int main_argc, gargs_preemp, gargs_nopreemp;
++static void gargs();
++void main_argv() {
++  int tracks = 0;
++  gargs(main_argc, main_argv, &tracks);
++}
++void gargs(int, char *, int *tracksp) {
++  int tracks = *tracksp, wm;
++  for (;;) {
++    if (tracks == 0)
++      wm |= 4;
++    if (gargs_nopreemp)
++      gargs_preemp = 0;
++    if (tracks == 0 && wm == 0)
++      tracks++;
++  }
++}
+diff --git a/gcc/tree-ssa-sccvn.cc b/gcc/tree-ssa-sccvn.cc
+index 1967bbdca84d..9c460fc1bdb3 100644
 --- a/gcc/tree-ssa-sccvn.cc
 +++ b/gcc/tree-ssa-sccvn.cc
-@@ -7902,8 +7902,11 @@ insert_related_predicates_on_edge (enum tree_code code, tree *ops, edge pred_e)
+@@ -7897,6 +7897,7 @@ insert_related_predicates_on_edge (enum tree_code code, tree *ops, edge pred_e)
+ 
+ /* Insert on the TRUE_E true and FALSE_E false predicates
     derived from LHS CODE RHS.  */
++
  static void
  insert_predicates_for_cond (tree_code code, tree lhs, tree rhs,
--			    edge true_e, edge false_e)
-+			    edge true_e, edge false_e, int n = 0)
- {
-+  if (n > 5)
-+    return;
-+
-   /* If both edges are null, then there is nothing to be done. */
-   if (!true_e && !false_e)
-     return;
-@@ -7964,7 +7967,7 @@ insert_predicates_for_cond (tree_code code, tree lhs, tree rhs,
- 	    edge nf = false_e;
- 	    if (code == EQ_EXPR)
- 	      std::swap (nt, nf);
--	    insert_predicates_for_cond (nc, nlhs, nrhs, nt, nf);
-+	    insert_predicates_for_cond (nc, nlhs, nrhs, nt, nf, n + 1);
- 	  }
-       /* (a | b) == 0 ->
- 	    on true edge assert: a == 0 & b == 0. */
-@@ -7977,10 +7980,10 @@ insert_predicates_for_cond (tree_code code, tree lhs, tree rhs,
+ 			    edge true_e, edge false_e)
+@@ -7973,10 +7974,16 @@ insert_predicates_for_cond (tree_code code, tree lhs, tree rhs,
  	  tree nlhs;
  
  	  nlhs = vn_valueize (gimple_assign_rhs1 (def_stmt));
 -	  insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr);
-+	  insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr, n + 1);
++	  /* A valueization of the `a` might return the old lhs
++	     which is already handled above. */
++	  if (nlhs != lhs)
++	    insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr);
  
++	  /* A valueization of the `b` might return the old lhs
++	     which is already handled above. */
  	  nlhs = vn_valueize (gimple_assign_rhs2 (def_stmt));
 -	  insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr);
-+	  insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr, n + 1);
++	  if (nlhs != lhs)
++	    insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr);
  	}
      }
  }
+-- 
+2.47.0
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-09 16:24 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-09 16:24 UTC (permalink / raw
  To: gentoo-commits
commit:     58deeb29d8c568e8e0a633a8b6410d3a70b2808d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Nov  9 16:24:14 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Nov  9 16:24:42 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=58deeb29
15.0.0: drop 73_all_PR117493-sccvn-insert_predicates_for_cond-limit.patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...93-sccvn-insert_predicates_for_cond-limit.patch | 98 ----------------------
 1 file changed, 98 deletions(-)
diff --git a/15.0.0/gentoo/73_all_PR117493-sccvn-insert_predicates_for_cond-limit.patch b/15.0.0/gentoo/73_all_PR117493-sccvn-insert_predicates_for_cond-limit.patch
deleted file mode 100644
index 9816e52..0000000
--- a/15.0.0/gentoo/73_all_PR117493-sccvn-insert_predicates_for_cond-limit.patch
+++ /dev/null
@@ -1,98 +0,0 @@
-From a49a60790ae2032dfeee617ba9488fc80e09b3a8 Mon Sep 17 00:00:00 2001
-Message-ID: <a49a60790ae2032dfeee617ba9488fc80e09b3a8.1731138919.git.sam@gentoo.org>
-From: Andrew Pinski <quic_apinski@quicinc.com>
-Date: Fri, 8 Nov 2024 17:35:02 -0800
-Subject: [PATCH] VN: Don't recurse on for the same value of `a | b` [PR117496]
-
-After adding vn_valueize to the handle the `a | b ==/!= 0` case
-of insert_predicates_for_cond, it would go into an infinite loop
-as the Value number for either a or b could be the same as what it
-is for the whole expression. This avoids that recursion so there is
-no infinite loop here.
-
-Bootstrapped and tested on x86_64-linux.
-
-	PR tree-optimization/117496
-
-gcc/ChangeLog:
-
-	* tree-ssa-sccvn.cc (insert_predicates_for_cond): If the
-	valueization for the new lhs is the same as the old one,
-	don't recurse.
-
-gcc/testsuite/ChangeLog:
-
-	* gcc.dg/torture/pr117496-1.c: New test.
-
-Signed-off-by: Andrew Pinski <quic_apinski@quicinc.com>
----
- gcc/testsuite/gcc.dg/torture/pr117496-1.c | 25 +++++++++++++++++++++++
- gcc/tree-ssa-sccvn.cc                     | 11 ++++++++--
- 2 files changed, 34 insertions(+), 2 deletions(-)
- create mode 100644 gcc/testsuite/gcc.dg/torture/pr117496-1.c
-
-diff --git a/gcc/testsuite/gcc.dg/torture/pr117496-1.c b/gcc/testsuite/gcc.dg/torture/pr117496-1.c
-new file mode 100644
-index 000000000000..f35d13dfa85d
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/torture/pr117496-1.c
-@@ -0,0 +1,25 @@
-+/* { dg-do compile } */
-+
-+
-+/* PR tree-optimization/117496 */
-+/* This would go into an infinite loop into VN while recording
-+   the predicates for the `tracks == 0 && wm == 0` GIMPLE_COND.
-+   As wm_N and tracks_N would valueize back to `tracks | wm`.  */
-+
-+int main_argc, gargs_preemp, gargs_nopreemp;
-+static void gargs();
-+void main_argv() {
-+  int tracks = 0;
-+  gargs(main_argc, main_argv, &tracks);
-+}
-+void gargs(int, char *, int *tracksp) {
-+  int tracks = *tracksp, wm;
-+  for (;;) {
-+    if (tracks == 0)
-+      wm |= 4;
-+    if (gargs_nopreemp)
-+      gargs_preemp = 0;
-+    if (tracks == 0 && wm == 0)
-+      tracks++;
-+  }
-+}
-diff --git a/gcc/tree-ssa-sccvn.cc b/gcc/tree-ssa-sccvn.cc
-index 1967bbdca84d..9c460fc1bdb3 100644
---- a/gcc/tree-ssa-sccvn.cc
-+++ b/gcc/tree-ssa-sccvn.cc
-@@ -7897,6 +7897,7 @@ insert_related_predicates_on_edge (enum tree_code code, tree *ops, edge pred_e)
- 
- /* Insert on the TRUE_E true and FALSE_E false predicates
-    derived from LHS CODE RHS.  */
-+
- static void
- insert_predicates_for_cond (tree_code code, tree lhs, tree rhs,
- 			    edge true_e, edge false_e)
-@@ -7973,10 +7974,16 @@ insert_predicates_for_cond (tree_code code, tree lhs, tree rhs,
- 	  tree nlhs;
- 
- 	  nlhs = vn_valueize (gimple_assign_rhs1 (def_stmt));
--	  insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr);
-+	  /* A valueization of the `a` might return the old lhs
-+	     which is already handled above. */
-+	  if (nlhs != lhs)
-+	    insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr);
- 
-+	  /* A valueization of the `b` might return the old lhs
-+	     which is already handled above. */
- 	  nlhs = vn_valueize (gimple_assign_rhs2 (def_stmt));
--	  insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr);
-+	  if (nlhs != lhs)
-+	    insert_predicates_for_cond (EQ_EXPR, nlhs, rhs, e, nullptr);
- 	}
-     }
- }
--- 
-2.47.0
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-10 22:41 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-10 22:41 UTC (permalink / raw
  To: gentoo-commits
commit:     eebe373c98a3d9a22f3dadab26f1fadb7220f60c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Nov 10 22:40:37 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Nov 10 22:40:37 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=eebe373c
15.0.0: cut patchset 22
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 2d6aaf8..25ab12b 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+22	10 November 2024
+
+	+ 72_all_PR117476-revert.patch
+
 21	1 November 2024
 
 	+ 31_all_time64.patch	
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-11 19:46 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-11 19:46 UTC (permalink / raw
  To: gentoo-commits
commit:     9bb90d6a35c8ab572372dfcff42a0ecd7dd53952
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 11 19:44:42 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Nov 11 19:44:42 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=9bb90d6a
15.0.0: add 33_all_PR80677-cross-limits.patch
I needed this with a cross from amd64->s390 after doing crossdev as
normal but then upgrading them to 15 snapshots.
Bug: https://gcc.gnu.org/PR80677
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/33_all_PR80677-cross-limits.patch | 38 +++++++++++++++++++++++++
 15.0.0/gentoo/README.history                    |  4 +++
 2 files changed, 42 insertions(+)
diff --git a/15.0.0/gentoo/33_all_PR80677-cross-limits.patch b/15.0.0/gentoo/33_all_PR80677-cross-limits.patch
new file mode 100644
index 0000000..3cbef01
--- /dev/null
+++ b/15.0.0/gentoo/33_all_PR80677-cross-limits.patch
@@ -0,0 +1,38 @@
+https://gcc.gnu.org/PR80677
+--- a/gcc/limitx.h
++++ b/gcc/limitx.h
+@@ -29,7 +29,7 @@
+ #ifndef _GCC_LIMITS_H_  /* Terminated in limity.h.  */
+ #define _GCC_LIMITS_H_
+
+-#ifndef _LIBC_LIMITS_H_
++#if !defined(_LIBC_LIMITS_H_) && __has_include_next(<limits.h>)
+ /* Use "..." so that we find syslimits.h only in this same directory.  */
+ #include "syslimits.h"
+ #endif
+--- a/gcc/limity.h
++++ b/gcc/limity.h
+@@ -3,7 +3,7 @@
+
+ #else /* not _GCC_LIMITS_H_ */
+
+-#ifdef _GCC_NEXT_LIMITS_H
++#if defined(_GCC_NEXT_LIMITS_H) && __has_include_next(<limits.h>)
+ #include_next <limits.h>		/* recurse down to the real one */
+ #endif
+
+--- a/gcc/Makefile.in
++++ b/gcc/Makefile.in
+@@ -3344,11 +3344,7 @@ stmp-int-hdrs: $(STMP_FIXINC) $(T_GLIMITS_H) $(T_STDINT_GCC_H) $(USER_H) fixinc_
+ 	  sysroot_headers_suffix=`echo $${ml} | sed -e 's/;.*$$//'`; \
+ 	  multi_dir=`echo $${ml} | sed -e 's/^[^;]*;//'`; \
+ 	  include_dir=include$${multi_dir}; \
+-	  if $(LIMITS_H_TEST) ; then \
+-	    cat $(srcdir)/limitx.h $(T_GLIMITS_H) $(srcdir)/limity.h > tmp-xlimits.h; \
+-	  else \
+-	    cat $(T_GLIMITS_H) > tmp-xlimits.h; \
+-	  fi; \
++	  cat $(srcdir)/limitx.h $(T_GLIMITS_H) $(srcdir)/limity.h > tmp-xlimits.h; \
+ 	  $(mkinstalldirs) $${include_dir}; \
+ 	  chmod a+rx $${include_dir} || true; \
+ 	  $(SHELL) $(srcdir)/../move-if-change \
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 25ab12b..dbf2b56 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+23	11 November 2024
+
+	+ 33_all_PR80677-cross-limits.patch
+
 22	10 November 2024
 
 	+ 72_all_PR117476-revert.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-11 19:46 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-11 19:46 UTC (permalink / raw
  To: gentoo-commits
commit:     c19b98e5b8997c997dbde31fe6d6db895b37dca7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 11 19:45:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Nov 11 19:45:15 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=c19b98e5
15.0.0: rename 31_all_time64.patch -> 32_all_time64.patch
Numbering conflict.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/{31_all_time64.patch => 32_all_time64.patch} | 0
 1 file changed, 0 insertions(+), 0 deletions(-)
diff --git a/15.0.0/gentoo/31_all_time64.patch b/15.0.0/gentoo/32_all_time64.patch
similarity index 100%
rename from 15.0.0/gentoo/31_all_time64.patch
rename to 15.0.0/gentoo/32_all_time64.patch
^ permalink raw reply	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-12  2:33 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-12  2:33 UTC (permalink / raw
  To: gentoo-commits
commit:     8209a4e7304772b31beca172c0397c76bcee4876
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Nov 12 02:33:40 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Nov 12 02:33:40 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=8209a4e7
15.0.0: rebase 26_all_enable-cet.patch
-fmodules-ts was renamed to -fmodules.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/26_all_enable-cet.patch | 34 +++++++++++++++++-----------------
 1 file changed, 17 insertions(+), 17 deletions(-)
diff --git a/15.0.0/gentoo/26_all_enable-cet.patch b/15.0.0/gentoo/26_all_enable-cet.patch
index b9bbbf0..85591e9 100644
--- a/15.0.0/gentoo/26_all_enable-cet.patch
+++ b/15.0.0/gentoo/26_all_enable-cet.patch
@@ -11,34 +11,34 @@ Needs:
 Only supported on amd64.
 --- a/gcc/cp/lang-specs.h
 +++ b/gcc/cp/lang-specs.h
-@@ -51,7 +51,7 @@ along with GCC; see the file COPYING3.  If not see
+@@ -57,7 +57,7 @@ along with GCC; see the file COPYING3.  If not see
        " 	   %{save-temps*:%b.ii} %{!save-temps*:%g.ii}}"
        "  %{!save-temps*:%{!no-integrated-cpp:%(cpp_unique_options)}}"
-       "  %{fmodules-ts:-fmodule-header %{fpreprocessed:-fdirectives-only}}"
+       "  %{fmodules*:-fmodule-header %{fpreprocessed:-fdirectives-only}}"
 -      "  %(cc1_options) %2"
 +      "  %(cc1_options) %(default_flag_cf_spec) %2"
        "  %{!fsyntax-only:"
        "    %{!S:-o %g.s}"
-       "    %{!fmodule-*:%{!fmodules-*:%{!fdump-ada-spec*:"
-@@ -72,7 +72,7 @@ along with GCC; see the file COPYING3.  If not see
+       "    %{!fmodule-*:%{!fmodules*:%{!fdump-ada-spec*:"
+@@ -78,7 +78,7 @@ along with GCC; see the file COPYING3.  If not see
        "  %{!save-temps*:%{!no-integrated-cpp:%(cpp_unique_options)}}"
-       "  %{fmodules-ts:-fmodule-header=system"
+       "  %{fmodules*:-fmodule-header=system"
        "    %{fpreprocessed:-fdirectives-only}}"
 -      "  %(cc1_options) %2"
 +      "  %(cc1_options) %(default_flag_cf_spec) %2"
        "  %{!fsyntax-only:"
        "    %{!S:-o %g.s}"
-       "    %{!fmodule-*:%{!fmodules-*:%{!fdump-ada-spec*:"
-@@ -92,7 +92,7 @@ along with GCC; see the file COPYING3.  If not see
+       "    %{!fmodule-*:%{!fmodules*:%{!fdump-ada-spec*:"
+@@ -98,7 +98,7 @@ along with GCC; see the file COPYING3.  If not see
        " 	   %{save-temps*:%b.ii} %{!save-temps*:%g.ii}}"
        "  %{!save-temps*:%{!no-integrated-cpp:%(cpp_unique_options)}}"
-       "  %{fmodules-ts:-fmodule-header=user %{fpreprocessed:-fdirectives-only}}"
+       "  %{fmodules*:-fmodule-header=user %{fpreprocessed:-fdirectives-only}}"
 -      "  %(cc1_options) %2"
 +      "  %(cc1_options) %(default_flag_cf_spec) %2"
        "  %{!fsyntax-only:"
        "    %{!S:-o %g.s}"
-       "    %{!fmodule-*:%{!fmodules-*:%{!fdump-ada-spec*:"
-@@ -107,7 +107,7 @@ along with GCC; see the file COPYING3.  If not see
+       "    %{!fmodule-*:%{!fmodules*:%{!fdump-ada-spec*:"
+@@ -113,7 +113,7 @@ along with GCC; see the file COPYING3.  If not see
        "  cc1plus %{save-temps*|no-integrated-cpp:-fpreprocessed"
        " 	   %{save-temps*:%b.ii} %{!save-temps*:%g.ii}}"
        "  %{!save-temps*:%{!no-integrated-cpp:%(cpp_unique_options)}}"
@@ -47,7 +47,7 @@ Only supported on amd64.
        "  %{!fsyntax-only:"
        "    %{fmodule-only:%{!S:-o %g.s%V}}"
        "    %{!fmodule-only:%(invoke_as)}}"
-@@ -116,7 +116,7 @@ along with GCC; see the file COPYING3.  If not see
+@@ -122,7 +122,7 @@ along with GCC; see the file COPYING3.  If not see
    {".ii", "@c++-cpp-output", 0, 0, 0},
    {"@c++-cpp-output",
        "%{!E:%{!M:%{!MM:"
@@ -58,7 +58,7 @@ Only supported on amd64.
        "    %{!fmodule-only:%{!fmodule-header*:%(invoke_as)}}}"
 --- a/gcc/gcc.cc
 +++ b/gcc/gcc.cc
-@@ -999,6 +999,18 @@ proper position among the other output files.  */
+@@ -1011,6 +1011,18 @@ proper position among the other output files.  */
  #define LINK_NOW_SPEC ""
  #endif
  
@@ -77,7 +77,7 @@ Only supported on amd64.
  #ifdef ENABLE_DEFAULT_PIE
  #define PIE_SPEC		"!no-pie"
  #define NO_FPIE1_SPEC		"fno-pie"
-@@ -1201,6 +1213,7 @@ static const char *cpp_spec = CPP_SPEC;
+@@ -1217,6 +1229,7 @@ static const char *cpp_spec = CPP_SPEC;
  static const char *cc1_spec = CC1_SPEC OS_CC1_SPEC;
  static const char *cc1plus_spec = CC1PLUS_SPEC;
  static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
@@ -85,7 +85,7 @@ Only supported on amd64.
  static const char *link_ssp_spec = LINK_SSP_SPEC;
  static const char *asm_spec = ASM_SPEC;
  static const char *asm_final_spec = ASM_FINAL_SPEC;
-@@ -1261,7 +1274,7 @@ static const char *cpp_options =
+@@ -1277,7 +1290,7 @@ static const char *cpp_options =
  "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
   %{f*} %{g*:%{%:debug-level-gt(0):%{g*}\
   %{!fno-working-directory:-fworking-directory}}} %{O*}\
@@ -94,7 +94,7 @@ Only supported on amd64.
  
  /* Pass -d* flags, possibly modifying -dumpdir, -dumpbase et al.
  
-@@ -1455,9 +1468,9 @@ static const struct compiler default_compilers[] =
+@@ -1471,9 +1484,9 @@ static const struct compiler default_compilers[] =
        %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
  	  %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
  	    cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
@@ -106,7 +106,7 @@ Only supported on amd64.
        %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
    {"-",
     "%{!E:%e-E or -x required when input is from standard input}\
-@@ -1482,7 +1495,7 @@ static const struct compiler default_compilers[] =
+@@ -1498,7 +1511,7 @@ static const struct compiler default_compilers[] =
  					   %W{o*:--output-pch %w%*}}%{!S:%V}}}}}}}}", 0, 0, 0},
    {".i", "@cpp-output", 0, 0, 0},
    {"@cpp-output",
@@ -115,7 +115,7 @@ Only supported on amd64.
    {".s", "@assembler", 0, 0, 0},
    {"@assembler",
     "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
-@@ -1714,6 +1727,7 @@ static struct spec_list static_specs[] =
+@@ -1730,6 +1743,7 @@ static struct spec_list static_specs[] =
    INIT_STATIC_SPEC ("cc1_options",		&cc1_options),
    INIT_STATIC_SPEC ("cc1plus",			&cc1plus_spec),
    INIT_STATIC_SPEC ("link_gcc_c_sequence",	&link_gcc_c_sequence_spec),
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-13  0:16 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-13  0:16 UTC (permalink / raw
  To: gentoo-commits
commit:     dc56acd66a2e3cbbc1f1a62f02538d668f4a843b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 13 00:16:04 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov 13 00:16:04 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=dc56acd6
15.0.0: drop 72_all_PR117476-revert.patch
The revert has landed upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117476-revert.patch | 74 ------------------------------
 1 file changed, 74 deletions(-)
diff --git a/15.0.0/gentoo/72_all_PR117476-revert.patch b/15.0.0/gentoo/72_all_PR117476-revert.patch
deleted file mode 100644
index c073213..0000000
--- a/15.0.0/gentoo/72_all_PR117476-revert.patch
+++ /dev/null
@@ -1,74 +0,0 @@
-From 7f98f96e02bd3b5cac35655d933382f9225fef59 Mon Sep 17 00:00:00 2001
-Message-ID: <7f98f96e02bd3b5cac35655d933382f9225fef59.1730995976.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Thu, 7 Nov 2024 16:12:40 +0000
-Subject: [PATCH] Revert "[PATCH v2] RISC-V: zero_extend(not) -> xor
- optimization [PR112398]"
-
-This reverts commit 69bd93c167fefbdff0cb88614275358b7a2b2941.
-
-Bug: https://gcc.gnu.org/PR117476
----
- gcc/simplify-rtx.cc                       | 22 ----------------------
- gcc/testsuite/gcc.target/riscv/pr112398.c | 14 --------------
- 2 files changed, 36 deletions(-)
- delete mode 100644 gcc/testsuite/gcc.target/riscv/pr112398.c
-
-diff --git a/gcc/simplify-rtx.cc b/gcc/simplify-rtx.cc
-index d05efac20dc8..893c5f6e1ae0 100644
---- a/gcc/simplify-rtx.cc
-+++ b/gcc/simplify-rtx.cc
-@@ -1842,28 +1842,6 @@ simplify_context::simplify_unary_operation_1 (rtx_code code, machine_mode mode,
- 	      & ~GET_MODE_MASK (op_mode)) == 0)
- 	return SUBREG_REG (op);
- 
--      /* Trying to optimize:
--	 (zero_extend:M (subreg:N (not:M (X:M)))) ->
--	 (xor:M (zero_extend:M (subreg:N (X:M)), mask))
--	 where the mask is GET_MODE_MASK (N).
--	 For the cases when X:M doesn't have any non-zero bits
--	 outside of mode N, (zero_extend:M (subreg:N (X:M))
--	 will be simplified to just (X:M)
--	 and whole optimization will be -> (xor:M (X:M, mask)).  */
--      if (SUBREG_P (op)
--	  && GET_CODE (XEXP (op, 0)) == NOT
--	  && GET_MODE (XEXP (op, 0)) == mode
--	  && subreg_lowpart_p (op)
--	  && GET_MODE_SIZE (GET_MODE (op)).is_constant ()
--	  && (nonzero_bits (XEXP (XEXP (op, 0), 0), mode)
--	      & ~GET_MODE_MASK (mode)) == 0)
--      {
--	const uint64_t mask = GET_MODE_MASK (GET_MODE (op));
--	return simplify_gen_binary (XOR, mode,
--				    XEXP (XEXP (op, 0), 0),
--				    gen_int_mode (mask, mode));
--      }
--
- #if defined(POINTERS_EXTEND_UNSIGNED)
-       /* As we do not know which address space the pointer is referring to,
- 	 we can do this only if the target does not support different pointer
-diff --git a/gcc/testsuite/gcc.target/riscv/pr112398.c b/gcc/testsuite/gcc.target/riscv/pr112398.c
-deleted file mode 100644
-index 624a665b76c9..000000000000
---- a/gcc/testsuite/gcc.target/riscv/pr112398.c
-+++ /dev/null
-@@ -1,14 +0,0 @@
--/* { dg-do compile } */
--/* { dg-options "-march=rv64gc -mabi=lp64d" } */
--/* { dg-skip-if "" { *-*-* } { "-O0" "-Og" } } */
--
--#include <stdint.h>
--
--uint8_t neg_u8 (const uint8_t src)
--{
--  return ~src;
--}
--
--/* { dg-final { scan-assembler-times "xori\t" 1 } } */
--/* { dg-final { scan-assembler-not "not\t" } } */
--/* { dg-final { scan-assembler-not "andi\t" } } */
-
-base-commit: 6a6b8b847bce78a909379f3b9d3365c4ac4f0ff5
--- 
-2.47.0
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-13  4:26 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-13  4:26 UTC (permalink / raw
  To: gentoo-commits
commit:     103f6d1d6a6291a214d420a6279ebe3a99b83981
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 13 04:26:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov 13 04:26:15 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=103f6d1d
15.0.0: bring back 72_all_PR117476-revert.patch
It seems to have reappeared on trunk...
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117476-revert.patch | 74 ++++++++++++++++++++++++++++++
 1 file changed, 74 insertions(+)
diff --git a/15.0.0/gentoo/72_all_PR117476-revert.patch b/15.0.0/gentoo/72_all_PR117476-revert.patch
new file mode 100644
index 0000000..35c60bf
--- /dev/null
+++ b/15.0.0/gentoo/72_all_PR117476-revert.patch
@@ -0,0 +1,74 @@
+From df77b7d66ca5dee0130765f37d8afba29f0f1f28 Mon Sep 17 00:00:00 2001
+Message-ID: <df77b7d66ca5dee0130765f37d8afba29f0f1f28.1731471945.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Wed, 13 Nov 2024 04:25:31 +0000
+Subject: [PATCH] Revert "Reapply "[PATCH v2] RISC-V: zero_extend(not) -> xor
+ optimization [PR112398]""
+
+This reverts commit 10d76b7f1e5b63ad6d2b92940c39007913ced037.
+
+Bug: https://gcc.gnu.org/PR117476
+---
+ gcc/simplify-rtx.cc                       | 22 ----------------------
+ gcc/testsuite/gcc.target/riscv/pr112398.c | 14 --------------
+ 2 files changed, 36 deletions(-)
+ delete mode 100644 gcc/testsuite/gcc.target/riscv/pr112398.c
+
+diff --git a/gcc/simplify-rtx.cc b/gcc/simplify-rtx.cc
+index d05efac20dc8..893c5f6e1ae0 100644
+--- a/gcc/simplify-rtx.cc
++++ b/gcc/simplify-rtx.cc
+@@ -1842,28 +1842,6 @@ simplify_context::simplify_unary_operation_1 (rtx_code code, machine_mode mode,
+ 	      & ~GET_MODE_MASK (op_mode)) == 0)
+ 	return SUBREG_REG (op);
+ 
+-      /* Trying to optimize:
+-	 (zero_extend:M (subreg:N (not:M (X:M)))) ->
+-	 (xor:M (zero_extend:M (subreg:N (X:M)), mask))
+-	 where the mask is GET_MODE_MASK (N).
+-	 For the cases when X:M doesn't have any non-zero bits
+-	 outside of mode N, (zero_extend:M (subreg:N (X:M))
+-	 will be simplified to just (X:M)
+-	 and whole optimization will be -> (xor:M (X:M, mask)).  */
+-      if (SUBREG_P (op)
+-	  && GET_CODE (XEXP (op, 0)) == NOT
+-	  && GET_MODE (XEXP (op, 0)) == mode
+-	  && subreg_lowpart_p (op)
+-	  && GET_MODE_SIZE (GET_MODE (op)).is_constant ()
+-	  && (nonzero_bits (XEXP (XEXP (op, 0), 0), mode)
+-	      & ~GET_MODE_MASK (mode)) == 0)
+-      {
+-	const uint64_t mask = GET_MODE_MASK (GET_MODE (op));
+-	return simplify_gen_binary (XOR, mode,
+-				    XEXP (XEXP (op, 0), 0),
+-				    gen_int_mode (mask, mode));
+-      }
+-
+ #if defined(POINTERS_EXTEND_UNSIGNED)
+       /* As we do not know which address space the pointer is referring to,
+ 	 we can do this only if the target does not support different pointer
+diff --git a/gcc/testsuite/gcc.target/riscv/pr112398.c b/gcc/testsuite/gcc.target/riscv/pr112398.c
+deleted file mode 100644
+index 624a665b76c9..000000000000
+--- a/gcc/testsuite/gcc.target/riscv/pr112398.c
++++ /dev/null
+@@ -1,14 +0,0 @@
+-/* { dg-do compile } */
+-/* { dg-options "-march=rv64gc -mabi=lp64d" } */
+-/* { dg-skip-if "" { *-*-* } { "-O0" "-Og" } } */
+-
+-#include <stdint.h>
+-
+-uint8_t neg_u8 (const uint8_t src)
+-{
+-  return ~src;
+-}
+-
+-/* { dg-final { scan-assembler-times "xori\t" 1 } } */
+-/* { dg-final { scan-assembler-not "not\t" } } */
+-/* { dg-final { scan-assembler-not "andi\t" } } */
+
+base-commit: 445d8bb6a89eb2275c4930ec87a98d5123e5abdd
+-- 
+2.47.0
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-14 18:38 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-14 18:38 UTC (permalink / raw
  To: gentoo-commits
commit:     1055347293b49e411dc12e767faecfe9dcbfa8cf
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Nov 14 18:37:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Nov 14 18:37:39 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=10553472
15.0.0: drop 72_all_PR117476-revert.patch
It's now been properly reverted again.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117476-revert.patch | 74 ------------------------------
 1 file changed, 74 deletions(-)
diff --git a/15.0.0/gentoo/72_all_PR117476-revert.patch b/15.0.0/gentoo/72_all_PR117476-revert.patch
deleted file mode 100644
index 35c60bf..0000000
--- a/15.0.0/gentoo/72_all_PR117476-revert.patch
+++ /dev/null
@@ -1,74 +0,0 @@
-From df77b7d66ca5dee0130765f37d8afba29f0f1f28 Mon Sep 17 00:00:00 2001
-Message-ID: <df77b7d66ca5dee0130765f37d8afba29f0f1f28.1731471945.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Wed, 13 Nov 2024 04:25:31 +0000
-Subject: [PATCH] Revert "Reapply "[PATCH v2] RISC-V: zero_extend(not) -> xor
- optimization [PR112398]""
-
-This reverts commit 10d76b7f1e5b63ad6d2b92940c39007913ced037.
-
-Bug: https://gcc.gnu.org/PR117476
----
- gcc/simplify-rtx.cc                       | 22 ----------------------
- gcc/testsuite/gcc.target/riscv/pr112398.c | 14 --------------
- 2 files changed, 36 deletions(-)
- delete mode 100644 gcc/testsuite/gcc.target/riscv/pr112398.c
-
-diff --git a/gcc/simplify-rtx.cc b/gcc/simplify-rtx.cc
-index d05efac20dc8..893c5f6e1ae0 100644
---- a/gcc/simplify-rtx.cc
-+++ b/gcc/simplify-rtx.cc
-@@ -1842,28 +1842,6 @@ simplify_context::simplify_unary_operation_1 (rtx_code code, machine_mode mode,
- 	      & ~GET_MODE_MASK (op_mode)) == 0)
- 	return SUBREG_REG (op);
- 
--      /* Trying to optimize:
--	 (zero_extend:M (subreg:N (not:M (X:M)))) ->
--	 (xor:M (zero_extend:M (subreg:N (X:M)), mask))
--	 where the mask is GET_MODE_MASK (N).
--	 For the cases when X:M doesn't have any non-zero bits
--	 outside of mode N, (zero_extend:M (subreg:N (X:M))
--	 will be simplified to just (X:M)
--	 and whole optimization will be -> (xor:M (X:M, mask)).  */
--      if (SUBREG_P (op)
--	  && GET_CODE (XEXP (op, 0)) == NOT
--	  && GET_MODE (XEXP (op, 0)) == mode
--	  && subreg_lowpart_p (op)
--	  && GET_MODE_SIZE (GET_MODE (op)).is_constant ()
--	  && (nonzero_bits (XEXP (XEXP (op, 0), 0), mode)
--	      & ~GET_MODE_MASK (mode)) == 0)
--      {
--	const uint64_t mask = GET_MODE_MASK (GET_MODE (op));
--	return simplify_gen_binary (XOR, mode,
--				    XEXP (XEXP (op, 0), 0),
--				    gen_int_mode (mask, mode));
--      }
--
- #if defined(POINTERS_EXTEND_UNSIGNED)
-       /* As we do not know which address space the pointer is referring to,
- 	 we can do this only if the target does not support different pointer
-diff --git a/gcc/testsuite/gcc.target/riscv/pr112398.c b/gcc/testsuite/gcc.target/riscv/pr112398.c
-deleted file mode 100644
-index 624a665b76c9..000000000000
---- a/gcc/testsuite/gcc.target/riscv/pr112398.c
-+++ /dev/null
-@@ -1,14 +0,0 @@
--/* { dg-do compile } */
--/* { dg-options "-march=rv64gc -mabi=lp64d" } */
--/* { dg-skip-if "" { *-*-* } { "-O0" "-Og" } } */
--
--#include <stdint.h>
--
--uint8_t neg_u8 (const uint8_t src)
--{
--  return ~src;
--}
--
--/* { dg-final { scan-assembler-times "xori\t" 1 } } */
--/* { dg-final { scan-assembler-not "not\t" } } */
--/* { dg-final { scan-assembler-not "andi\t" } } */
-
-base-commit: 445d8bb6a89eb2275c4930ec87a98d5123e5abdd
--- 
-2.47.0
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-18  9:25 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-18  9:25 UTC (permalink / raw
  To: gentoo-commits
commit:     ff918f6d0aac410a08f27a635f8b622c86097347
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 18 09:25:06 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Nov 18 09:25:06 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ff918f6d
15.0.0: add 72_all_PR117628-libgcc-c23.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117628-libgcc-c23.patch | 71 ++++++++++++++++++++++++++
 15.0.0/gentoo/README.history                   |  4 ++
 2 files changed, 75 insertions(+)
diff --git a/15.0.0/gentoo/72_all_PR117628-libgcc-c23.patch b/15.0.0/gentoo/72_all_PR117628-libgcc-c23.patch
new file mode 100644
index 0000000..ddfb652
--- /dev/null
+++ b/15.0.0/gentoo/72_all_PR117628-libgcc-c23.patch
@@ -0,0 +1,71 @@
+From b750323260c1ceb47c64e98ddab7095696b00a6d Mon Sep 17 00:00:00 2001
+Message-ID: <b750323260c1ceb47c64e98ddab7095696b00a6d.1731921825.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Mon, 18 Nov 2024 09:22:33 +0000
+Subject: [PATCH] libgcc: fix C23 issues
+
+This includes Jeff's patch from https://inbox.sourceware.org/gcc-patches/9cb69002-9754-476a-a525-68dcca9c23d8@gmail.com/.
+
+Bug: https://gcc.gnu.org/PR117628
+--- a/libgcc/config/arm/linux-atomic-64bit.c
++++ b/libgcc/config/arm/linux-atomic-64bit.c
+@@ -141,9 +141,7 @@ __sync_val_compare_and_swap_8 (long long *ptr, long long oldval,
+     }
+ }
+ 
+-typedef unsigned char bool;
+-
+-bool HIDDEN
++unsigned char HIDDEN
+ __sync_bool_compare_and_swap_8 (long long *ptr, long long oldval,
+ 				 long long newval)
+ {
+--- a/libgcc/config/arm/linux-atomic.c
++++ b/libgcc/config/arm/linux-atomic.c
+@@ -249,9 +249,7 @@ __sync_val_compare_and_swap_4 (int *ptr, int oldval, int newval)
+ SUBWORD_VAL_CAS (short,       2)
+ SUBWORD_VAL_CAS (signed char, 1)
+ 
+-typedef unsigned char bool;
+-
+-bool HIDDEN
++unsigned char HIDDEN
+ __sync_bool_compare_and_swap_4 (int *ptr, int oldval, int newval)
+ {
+   int failure = __kernel_cmpxchg (oldval, newval, ptr);
+@@ -259,7 +257,7 @@ __sync_bool_compare_and_swap_4 (int *ptr, int oldval, int newval)
+ }
+ 
+ #define SUBWORD_BOOL_CAS(TYPE, WIDTH)					\
+-  bool HIDDEN								\
++  unsigned char HIDDEN								\
+   __sync_bool_compare_and_swap_##WIDTH (TYPE *ptr, TYPE oldval,		\
+ 					TYPE newval)			\
+   {									\
+--- a/libgcc/config/csky/linux-atomic.c
++++ b/libgcc/config/csky/linux-atomic.c
+@@ -215,8 +215,6 @@ __sync_val_compare_and_swap_4 (int *ptr, int oldval, int newval)
+ SUBWORD_VAL_CAS (unsigned short, 2)
+ SUBWORD_VAL_CAS (unsigned char,	1)
+ 
+-typedef unsigned char bool;
+-
+ bool HIDDEN
+ __sync_bool_compare_and_swap_4 (int *ptr, int oldval, int newval)
+ {
+--- a/libgcc/unwind-arm-common.inc
++++ b/libgcc/unwind-arm-common.inc
+@@ -52,8 +52,6 @@
+ 
+ /* Definitions for C++ runtime support routines.  We make these weak
+    declarations to avoid pulling in libsupc++ unnecessarily.  */
+-typedef unsigned char bool;
+-
+ typedef struct _ZSt9type_info type_info; /* This names C++ type_info type */
+ enum __cxa_type_match_result
+   {
+
+base-commit: 45a3277149d95a51cf9109cab87ee39a7dce73e2
+-- 
+2.47.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 6da1d89..af598af 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+25	18 November 2024
+
+	+ 72_all_PR117628-libgcc-c23.patch
+
 24	16 November 2024
 
 	- 72_all_PR117476-revert.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-18  9:25 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-18  9:25 UTC (permalink / raw
  To: gentoo-commits
commit:     f502c6a7b5a5ea7666dd97267083e7828a7209eb
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 18 01:38:06 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Nov 18 01:38:06 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=f502c6a7
15.0.0: cut patchset 24
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index dbf2b56..6da1d89 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+24	16 November 2024
+
+	- 72_all_PR117476-revert.patch
+
 23	11 November 2024
 
 	+ 33_all_PR80677-cross-limits.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-18 10:42 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-18 10:42 UTC (permalink / raw
  To: gentoo-commits
commit:     2d962d0ca362f375f13b52ed638a2b183b4cb062
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 18 10:39:22 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Nov 18 10:39:22 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=2d962d0c
15.0.0: add 73_all_PR117646-match-Fix-the-max-a-b-0-pattern-for-pointers.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...ch-Fix-the-max-a-b-0-pattern-for-pointers.patch | 83 ++++++++++++++++++++++
 15.0.0/gentoo/README.history                       |  4 ++
 2 files changed, 87 insertions(+)
diff --git a/15.0.0/gentoo/73_all_PR117646-match-Fix-the-max-a-b-0-pattern-for-pointers.patch b/15.0.0/gentoo/73_all_PR117646-match-Fix-the-max-a-b-0-pattern-for-pointers.patch
new file mode 100644
index 0000000..c0ab935
--- /dev/null
+++ b/15.0.0/gentoo/73_all_PR117646-match-Fix-the-max-a-b-0-pattern-for-pointers.patch
@@ -0,0 +1,83 @@
+From 45a3277149d95a51cf9109cab87ee39a7dce73e2 Mon Sep 17 00:00:00 2001
+Message-ID: <45a3277149d95a51cf9109cab87ee39a7dce73e2.1731926298.git.sam@gentoo.org>
+From: Andrew Pinski <quic_apinski@quicinc.com>
+Date: Sun, 17 Nov 2024 20:21:58 -0800
+Subject: [PATCH] match: Fix the `max<a,b>==0` pattern for pointers [PR117646]
+
+For pointers I forgot that BIT_IOR_EXPR is not valid so when
+I added the pattern to convert `max<a,b> != 0` (r15-5356), GCC
+would start to ICEing saying pointer types were not valid for
+BIT_IOR_EXPR.
+This fixes the problem by casting to the unsigned type of the
+inner type. There was another way of fixing this to handling it
+as `a == 0 & b == 0` but both match and reassoication (for pointers)
+will then convert it back into the form I am creating here so
+let's just use that form instead.
+
+Bootstrapped and tested on x86_64-linux-gnu.
+
+	PR tree-optimization/117646
+
+gcc/ChangeLog:
+
+	* match.pd (`max<a,b>==0`): Add casts to `unsigned type`.
+
+gcc/testsuite/ChangeLog:
+
+	* gcc.dg/torture/minmaxneeqptr-1.c: New test.
+
+Signed-off-by: Andrew Pinski <quic_apinski@quicinc.com>
+---
+ gcc/match.pd                                  |  6 ++++--
+ .../gcc.dg/torture/minmaxneeqptr-1.c          | 21 +++++++++++++++++++
+ 2 files changed, 25 insertions(+), 2 deletions(-)
+ create mode 100644 gcc/testsuite/gcc.dg/torture/minmaxneeqptr-1.c
+
+diff --git a/gcc/match.pd b/gcc/match.pd
+index 4bec24a21b29..f5181325f3b9 100644
+--- a/gcc/match.pd
++++ b/gcc/match.pd
+@@ -4799,9 +4799,11 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
+    MAX (A, B) != 0 -> (A|B) != 0 iff unsigned.  */
+ (for cmp (eq ne)
+  (simplify
+-  (cmp (max @0 @1) integer_zerop@2)
++  (cmp (max @0 @1) integer_zerop)
+   (if (TYPE_UNSIGNED (TREE_TYPE (@0)))
+-   (cmp (bit_ior @0 @1) @2))))
++   (with { tree utype = unsigned_type_for (TREE_TYPE (@0)); }
++    (cmp (bit_ior (convert:utype @0) (convert:utype @1))
++         { build_zero_cst (utype); } )))))
+ 
+ /* Undo fancy ways of writing max/min or other ?: expressions, like
+    a - ((a - b) & -(a < b))  and  a - (a - b) * (a < b) into (a < b) ? b : a.
+diff --git a/gcc/testsuite/gcc.dg/torture/minmaxneeqptr-1.c b/gcc/testsuite/gcc.dg/torture/minmaxneeqptr-1.c
+new file mode 100644
+index 000000000000..aa45722330f4
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/torture/minmaxneeqptr-1.c
+@@ -0,0 +1,21 @@
++/* { dg-do compile } */
++
++/* PR tree-optimization/117646 */
++
++int maxeq(char *a, char *b) {
++  char *p = a < b ? b : a;
++  return p == (void*)0;
++}
++int maxne(char *a, char *b) {
++  char *p = a < b ? b : a;
++  return p == (void*)0;
++}
++
++int mineq(char *a, char *b) {
++  char *p = a > b ? b : a;
++  return p == (void*)0;
++}
++int minne(char *a, char *b) {
++  char *p = a > b ? b : a;
++  return p == (void*)0;
++}
+-- 
+2.47.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index af598af..df484a6 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+26	18 November 2024
+
+	+ 73_all_PR117646-match-Fix-the-max-a-b-0-pattern-for-pointers.patch
+
 25	18 November 2024
 
 	+ 72_all_PR117628-libgcc-c23.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-18 10:42 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-18 10:42 UTC (permalink / raw
  To: gentoo-commits
commit:     8174d657315852bd6a17d8d4f8084a54fc6a6f7f
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 18 10:41:53 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Nov 18 10:41:59 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=8174d657
15.0.0: drop 73_all_PR117646-match-Fix-the-max-a-b-0-pattern-for-pointers.patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...ch-Fix-the-max-a-b-0-pattern-for-pointers.patch | 83 ----------------------
 15.0.0/gentoo/README.history                       |  4 ++
 2 files changed, 4 insertions(+), 83 deletions(-)
diff --git a/15.0.0/gentoo/73_all_PR117646-match-Fix-the-max-a-b-0-pattern-for-pointers.patch b/15.0.0/gentoo/73_all_PR117646-match-Fix-the-max-a-b-0-pattern-for-pointers.patch
deleted file mode 100644
index c0ab935..0000000
--- a/15.0.0/gentoo/73_all_PR117646-match-Fix-the-max-a-b-0-pattern-for-pointers.patch
+++ /dev/null
@@ -1,83 +0,0 @@
-From 45a3277149d95a51cf9109cab87ee39a7dce73e2 Mon Sep 17 00:00:00 2001
-Message-ID: <45a3277149d95a51cf9109cab87ee39a7dce73e2.1731926298.git.sam@gentoo.org>
-From: Andrew Pinski <quic_apinski@quicinc.com>
-Date: Sun, 17 Nov 2024 20:21:58 -0800
-Subject: [PATCH] match: Fix the `max<a,b>==0` pattern for pointers [PR117646]
-
-For pointers I forgot that BIT_IOR_EXPR is not valid so when
-I added the pattern to convert `max<a,b> != 0` (r15-5356), GCC
-would start to ICEing saying pointer types were not valid for
-BIT_IOR_EXPR.
-This fixes the problem by casting to the unsigned type of the
-inner type. There was another way of fixing this to handling it
-as `a == 0 & b == 0` but both match and reassoication (for pointers)
-will then convert it back into the form I am creating here so
-let's just use that form instead.
-
-Bootstrapped and tested on x86_64-linux-gnu.
-
-	PR tree-optimization/117646
-
-gcc/ChangeLog:
-
-	* match.pd (`max<a,b>==0`): Add casts to `unsigned type`.
-
-gcc/testsuite/ChangeLog:
-
-	* gcc.dg/torture/minmaxneeqptr-1.c: New test.
-
-Signed-off-by: Andrew Pinski <quic_apinski@quicinc.com>
----
- gcc/match.pd                                  |  6 ++++--
- .../gcc.dg/torture/minmaxneeqptr-1.c          | 21 +++++++++++++++++++
- 2 files changed, 25 insertions(+), 2 deletions(-)
- create mode 100644 gcc/testsuite/gcc.dg/torture/minmaxneeqptr-1.c
-
-diff --git a/gcc/match.pd b/gcc/match.pd
-index 4bec24a21b29..f5181325f3b9 100644
---- a/gcc/match.pd
-+++ b/gcc/match.pd
-@@ -4799,9 +4799,11 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
-    MAX (A, B) != 0 -> (A|B) != 0 iff unsigned.  */
- (for cmp (eq ne)
-  (simplify
--  (cmp (max @0 @1) integer_zerop@2)
-+  (cmp (max @0 @1) integer_zerop)
-   (if (TYPE_UNSIGNED (TREE_TYPE (@0)))
--   (cmp (bit_ior @0 @1) @2))))
-+   (with { tree utype = unsigned_type_for (TREE_TYPE (@0)); }
-+    (cmp (bit_ior (convert:utype @0) (convert:utype @1))
-+         { build_zero_cst (utype); } )))))
- 
- /* Undo fancy ways of writing max/min or other ?: expressions, like
-    a - ((a - b) & -(a < b))  and  a - (a - b) * (a < b) into (a < b) ? b : a.
-diff --git a/gcc/testsuite/gcc.dg/torture/minmaxneeqptr-1.c b/gcc/testsuite/gcc.dg/torture/minmaxneeqptr-1.c
-new file mode 100644
-index 000000000000..aa45722330f4
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/torture/minmaxneeqptr-1.c
-@@ -0,0 +1,21 @@
-+/* { dg-do compile } */
-+
-+/* PR tree-optimization/117646 */
-+
-+int maxeq(char *a, char *b) {
-+  char *p = a < b ? b : a;
-+  return p == (void*)0;
-+}
-+int maxne(char *a, char *b) {
-+  char *p = a < b ? b : a;
-+  return p == (void*)0;
-+}
-+
-+int mineq(char *a, char *b) {
-+  char *p = a > b ? b : a;
-+  return p == (void*)0;
-+}
-+int minne(char *a, char *b) {
-+  char *p = a > b ? b : a;
-+  return p == (void*)0;
-+}
--- 
-2.47.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index df484a6..a17533c 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+??
+
+	- 73_all_PR117646-match-Fix-the-max-a-b-0-pattern-for-pointers.patch
+
 26	18 November 2024
 
 	+ 73_all_PR117646-match-Fix-the-max-a-b-0-pattern-for-pointers.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-18 17:25 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-18 17:25 UTC (permalink / raw
  To: gentoo-commits
commit:     aa56b526fa7d8766f57a7f24bedde612b00c197d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 18 17:24:23 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Nov 18 17:24:51 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=aa56b526
15.0.0: drop 72_all_PR117628-libgcc-c23.patch
Jeff's pushed another patch which includes these bits (and more).
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/72_all_PR117628-libgcc-c23.patch | 71 --------------------------
 15.0.0/gentoo/README.history                   |  1 +
 2 files changed, 1 insertion(+), 71 deletions(-)
diff --git a/15.0.0/gentoo/72_all_PR117628-libgcc-c23.patch b/15.0.0/gentoo/72_all_PR117628-libgcc-c23.patch
deleted file mode 100644
index ddfb652..0000000
--- a/15.0.0/gentoo/72_all_PR117628-libgcc-c23.patch
+++ /dev/null
@@ -1,71 +0,0 @@
-From b750323260c1ceb47c64e98ddab7095696b00a6d Mon Sep 17 00:00:00 2001
-Message-ID: <b750323260c1ceb47c64e98ddab7095696b00a6d.1731921825.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Mon, 18 Nov 2024 09:22:33 +0000
-Subject: [PATCH] libgcc: fix C23 issues
-
-This includes Jeff's patch from https://inbox.sourceware.org/gcc-patches/9cb69002-9754-476a-a525-68dcca9c23d8@gmail.com/.
-
-Bug: https://gcc.gnu.org/PR117628
---- a/libgcc/config/arm/linux-atomic-64bit.c
-+++ b/libgcc/config/arm/linux-atomic-64bit.c
-@@ -141,9 +141,7 @@ __sync_val_compare_and_swap_8 (long long *ptr, long long oldval,
-     }
- }
- 
--typedef unsigned char bool;
--
--bool HIDDEN
-+unsigned char HIDDEN
- __sync_bool_compare_and_swap_8 (long long *ptr, long long oldval,
- 				 long long newval)
- {
---- a/libgcc/config/arm/linux-atomic.c
-+++ b/libgcc/config/arm/linux-atomic.c
-@@ -249,9 +249,7 @@ __sync_val_compare_and_swap_4 (int *ptr, int oldval, int newval)
- SUBWORD_VAL_CAS (short,       2)
- SUBWORD_VAL_CAS (signed char, 1)
- 
--typedef unsigned char bool;
--
--bool HIDDEN
-+unsigned char HIDDEN
- __sync_bool_compare_and_swap_4 (int *ptr, int oldval, int newval)
- {
-   int failure = __kernel_cmpxchg (oldval, newval, ptr);
-@@ -259,7 +257,7 @@ __sync_bool_compare_and_swap_4 (int *ptr, int oldval, int newval)
- }
- 
- #define SUBWORD_BOOL_CAS(TYPE, WIDTH)					\
--  bool HIDDEN								\
-+  unsigned char HIDDEN								\
-   __sync_bool_compare_and_swap_##WIDTH (TYPE *ptr, TYPE oldval,		\
- 					TYPE newval)			\
-   {									\
---- a/libgcc/config/csky/linux-atomic.c
-+++ b/libgcc/config/csky/linux-atomic.c
-@@ -215,8 +215,6 @@ __sync_val_compare_and_swap_4 (int *ptr, int oldval, int newval)
- SUBWORD_VAL_CAS (unsigned short, 2)
- SUBWORD_VAL_CAS (unsigned char,	1)
- 
--typedef unsigned char bool;
--
- bool HIDDEN
- __sync_bool_compare_and_swap_4 (int *ptr, int oldval, int newval)
- {
---- a/libgcc/unwind-arm-common.inc
-+++ b/libgcc/unwind-arm-common.inc
-@@ -52,8 +52,6 @@
- 
- /* Definitions for C++ runtime support routines.  We make these weak
-    declarations to avoid pulling in libsupc++ unnecessarily.  */
--typedef unsigned char bool;
--
- typedef struct _ZSt9type_info type_info; /* This names C++ type_info type */
- enum __cxa_type_match_result
-   {
-
-base-commit: 45a3277149d95a51cf9109cab87ee39a7dce73e2
--- 
-2.47.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index a17533c..479b5cc 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 ??
 
+	- 72_all_PR117628-libgcc-c23.patch
 	- 73_all_PR117646-match-Fix-the-max-a-b-0-pattern-for-pointers.patch
 
 26	18 November 2024
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-24 22:42 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-24 22:42 UTC (permalink / raw
  To: gentoo-commits
commit:     37dff17dbf53946cffea53f5c0514f229f3be11d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Nov 24 22:41:57 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Nov 24 22:41:57 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=37dff17d
15.0.0: add 34_all_time64_ssemath.patch like for 14.2.0
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/34_all_time64_ssemath.patch | 43 +++++++++++++++++++++++++++++++
 15.0.0/gentoo/README.history              |  1 +
 2 files changed, 44 insertions(+)
diff --git a/15.0.0/gentoo/34_all_time64_ssemath.patch b/15.0.0/gentoo/34_all_time64_ssemath.patch
new file mode 100644
index 0000000..3701b6b
--- /dev/null
+++ b/15.0.0/gentoo/34_all_time64_ssemath.patch
@@ -0,0 +1,43 @@
+From 33ba5944f2b887fe8bddd541790645b74f1f2655 Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Micha=C5=82=20G=C3=B3rny?= <mgorny@gentoo.org>
+Date: Sun, 24 Nov 2024 14:45:37 +0100
+Subject: [PATCH] Default to -mfpmath=sse on x86 with time64
+
+Our time64 stages already default to `-mfpmath=sse`, so let's have
+the time64 flag implicitly enable it as the default to make things more
+consistent.  Furthermore, this also improves compatibility with clang
+that always enables it whenever the target architectures supports SSE.
+
+Note that this works only if `-march=` with SSE support is specified.
+We could technically improve the consistency even further by raising
+the default `-march=`, but that seems a bit intrusive and probably
+unnecessary, given that the vast majority of Gentoo users and/or
+upstream projects will specify `-march=`.
+
+See also:
+https://public-inbox.gentoo.org/gentoo-dev/ce894afe6c2b324fef012da9bb9387cfde7aed03.camel@gentoo.org/
+https://public-inbox.gentoo.org/gentoo-dev/baa1ca92da4941b0999ea2feecf02334b5b20ade.camel@gentoo.org/
+---
+ gcc/config/i386/i386-options.cc | 6 +++++-
+ 1 file changed, 5 insertions(+), 1 deletion(-)
+
+diff --git a/gcc/config/i386/i386-options.cc b/gcc/config/i386/i386-options.cc
+index 6c212a8ed..03801f382 100644
+--- a/gcc/config/i386/i386-options.cc
++++ b/gcc/config/i386/i386-options.cc
+@@ -2881,7 +2881,11 @@ ix86_option_override_internal (bool main_args_p,
+      Also -mfpmath=387 is overall a lot more compact (bout 4-5%) than SSE
+      codegen.  We may switch to 387 with -ffast-math for size optimized
+      functions. */
+-  else if (fast_math_flags_set_p (&global_options)
++#ifndef _GENTOO_TIME64_FORCE
++  #define _GENTOO_TIME64_FORCE 0
++#endif
++
++  else if ((fast_math_flags_set_p (&global_options) || _GENTOO_TIME64_FORCE)
+ 	   && TARGET_SSE2_P (opts->x_ix86_isa_flags))
+     opts->x_ix86_fpmath = FPMATH_SSE;
+   else
+-- 
+2.47.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 479b5cc..cf197b9 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 ??
 
+	+ 34_all_time64_ssemath.patch
 	- 72_all_PR117628-libgcc-c23.patch
 	- 73_all_PR117646-match-Fix-the-max-a-b-0-pattern-for-pointers.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-25  3:00 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-25  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     ad1e08717f7b9831b6017cc6c256963c43c704d7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 25 02:59:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Nov 25 02:59:53 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ad1e0871
15.0.0: add 72_all_PR111600-genemit-Distribute-evenly-to-files.patch
Bug: https://gcc.gnu.org/PR111600
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...111600-genemit-Distribute-evenly-to-files.patch | 194 +++++++++++++++++++++
 1 file changed, 194 insertions(+)
diff --git a/15.0.0/gentoo/72_all_PR111600-genemit-Distribute-evenly-to-files.patch b/15.0.0/gentoo/72_all_PR111600-genemit-Distribute-evenly-to-files.patch
new file mode 100644
index 0000000..287e082
--- /dev/null
+++ b/15.0.0/gentoo/72_all_PR111600-genemit-Distribute-evenly-to-files.patch
@@ -0,0 +1,194 @@
+https://inbox.sourceware.org/gcc-patches/D5S1TZK05IYW.2D2RLLK7L1ZQ1@gmail.com/
+
+From 359fea7741c6c8f98239aa32f5c3b6f4a582567b Mon Sep 17 00:00:00 2001
+Message-ID: <359fea7741c6c8f98239aa32f5c3b6f4a582567b.1732312478.git.sam@gentoo.org>
+From: Robin Dapp <rdapp.gcc@gmail.com>
+Date: Thu, 21 Nov 2024 18:56:32 +0100
+Subject: [PATCH] genemit: Distribute evenly to files [PR111600].
+
+Hi,
+
+currently we distribute insn patterns in genemit, partitioning them
+by the number of patterns per file.  The first 100 into file 1, the
+next 100 into file 2, and so on.  Depending on the patterns this
+can lead to files of very uneven size.
+
+Similar to the genmatch split, this patch introduces a dynamic
+choose_output () which considers the size of the output files
+and selects the shortest one for the next pattern.
+
+Bootstrapped and regtested on x86 and power10, aarch64 running.
+Regtested on rv64gcv.
+
+gcc/ChangeLog:
+
+	PR target/111600
+
+* genemit.cc (handle_arg): Use files instead of filenames.
+	(main): Ditto.
+	* gensupport.cc (SIZED_BASED_CHUNKS): Define.
+	(choose_output): New function.
+	* gensupport.h (choose_output): Declare.
+---
+ gcc/genemit.cc    | 53 ++++++++++++++---------------------------------
+ gcc/gensupport.cc | 33 +++++++++++++++++++++++++++++
+ gcc/gensupport.h  |  1 +
+ 3 files changed, 50 insertions(+), 37 deletions(-)
+
+diff --git a/gcc/genemit.cc b/gcc/genemit.cc
+index 5d3d10f5061a..518fb85ce8c8 100644
+--- a/gcc/genemit.cc
++++ b/gcc/genemit.cc
+@@ -905,14 +905,15 @@ from the machine description file `md'.  */\n\n");
+   fprintf (file, "#include \"target.h\"\n\n");
+ }
+ 
+-auto_vec<const char *, 10> output_files;
++auto_vec<FILE *, 10> output_files;
+ 
+ static bool
+ handle_arg (const char *arg)
+ {
+   if (arg[1] == 'O')
+     {
+-      output_files.safe_push (&arg[2]);
++      FILE *file = fopen (&arg[2], "w");
++      output_files.safe_push (file);
+       return true;
+     }
+   return false;
+@@ -933,47 +934,21 @@ main (int argc, const char **argv)
+   /* Assign sequential codes to all entries in the machine description
+      in parallel with the tables in insn-output.cc.  */
+ 
+-  int npatterns = count_patterns ();
+   md_rtx_info info;
+ 
+-  bool to_stdout = false;
+-  int npatterns_per_file = npatterns;
+-  if (!output_files.is_empty ())
+-    npatterns_per_file = npatterns / output_files.length () + 1;
+-  else
+-    to_stdout = true;
+-
+-  gcc_assert (npatterns_per_file > 1);
++  if (output_files.is_empty ())
++    output_files.safe_push (stdout);
+ 
+-  /* Reverse so we can pop the first-added element.  */
+-  output_files.reverse ();
++  for (auto f : output_files)
++    print_header (f);
+ 
+-  int count = 0;
+   FILE *file = NULL;
++  unsigned file_idx;
+ 
+   /* Read the machine description.  */
+   while (read_md_rtx (&info))
+     {
+-      if (count == 0 || count == npatterns_per_file)
+-	{
+-	  bool is_last = !to_stdout && output_files.is_empty ();
+-	  if (file && !is_last)
+-	    if (fclose (file) != 0)
+-	      return FATAL_EXIT_CODE;
+-
+-	  if (!output_files.is_empty ())
+-	    {
+-	      const char *const filename = output_files.pop ();
+-	      file = fopen (filename, "w");
+-	    }
+-	  else if (to_stdout)
+-	    file = stdout;
+-	  else
+-	    break;
+-
+-	  print_header (file);
+-	  count = 0;
+-	}
++      file = choose_output (output_files, file_idx);
+ 
+       switch (GET_CODE (info.def))
+ 	{
+@@ -999,10 +974,10 @@ main (int argc, const char **argv)
+ 	default:
+ 	  break;
+ 	}
+-
+-      count++;
+     }
+ 
++  file = choose_output (output_files, file_idx);
++
+   /* Write out the routines to add CLOBBERs to a pattern and say whether they
+      clobber a hard reg.  */
+   output_add_clobbers (&info, file);
+@@ -1015,5 +990,9 @@ main (int argc, const char **argv)
+       handle_overloaded_gen (oname, file);
+     }
+ 
+-  return (fclose (file) != 0 ? FATAL_EXIT_CODE : SUCCESS_EXIT_CODE);
++  for (FILE *f : output_files)
++    if (fclose (f) != 0)
++      return FATAL_EXIT_CODE;
++
++  return SUCCESS_EXIT_CODE;
+ }
+diff --git a/gcc/gensupport.cc b/gcc/gensupport.cc
+index 3a02132c8761..e0adf0c1bc54 100644
+--- a/gcc/gensupport.cc
++++ b/gcc/gensupport.cc
+@@ -3913,3 +3913,36 @@ find_optab (optab_pattern *p, const char *name)
+     }
+   return false;
+ }
++
++/* Find the file to write into next.  We try to evenly distribute the contents
++   over the different files.  */
++
++#define SIZED_BASED_CHUNKS 1
++
++FILE *
++choose_output (const vec<FILE *> &parts, unsigned &idx)
++{
++  if (parts.length () == 0)
++    gcc_unreachable ();
++#ifdef SIZED_BASED_CHUNKS
++  FILE *shortest = NULL;
++  long min = 0;
++  idx = 0;
++  for (unsigned i = 0; i < parts.length (); i++)
++    {
++      FILE *part  = parts[i];
++      long len = ftell (part);
++      if (!shortest || min > len)
++	{
++	  shortest = part;
++	  min = len;
++	  idx = i;
++       }
++    }
++  return shortest;
++#else
++  static int current_file;
++  idx = current_file++ % parts.length ();
++  return parts[idx];
++#endif
++}
+diff --git a/gcc/gensupport.h b/gcc/gensupport.h
+index b7a1da34518c..781c9e9ffcea 100644
+--- a/gcc/gensupport.h
++++ b/gcc/gensupport.h
+@@ -231,5 +231,6 @@ extern file_location get_file_location (rtx);
+ extern const char *get_emit_function (rtx);
+ extern bool needs_barrier_p (rtx);
+ extern bool find_optab (optab_pattern *, const char *);
++extern FILE *choose_output (const vec<FILE *> &, unsigned &);
+ 
+ #endif /* GCC_GENSUPPORT_H */
+
+base-commit: 76c202329458aad027ececc59d666e4995e3644e
+-- 
+2.47.0
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-25  3:00 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-25  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     1bd66ae9f12542821d29d7692284389f5ffb4e51
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Nov 24 22:42:41 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Nov 24 22:42:41 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=1bd66ae9
15.0.0: cut patchset 27
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index cf197b9..c8d1a49 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-??
+27	24 November 2024
 
 	+ 34_all_time64_ssemath.patch
 	- 72_all_PR117628-libgcc-c23.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-25  3:01 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-25  3:01 UTC (permalink / raw
  To: gentoo-commits
commit:     b42ad3974593603461104aacf942c53595108fa7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 25 03:01:43 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Nov 25 03:01:43 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b42ad397
15.0.0: cut patchset 28
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index c8d1a49..7a89c63 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+28	25 November 2024
+
+	+ 72_all_PR111600-genemit-Distribute-evenly-to-files.patch
+
 27	24 November 2024
 
 	+ 34_all_time64_ssemath.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-25 15:10 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-25 15:10 UTC (permalink / raw
  To: gentoo-commits
commit:     12bd49fdb9c159ea05e498160adef179467bc729
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 25 15:09:49 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Nov 25 15:09:49 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=12bd49fd
15.0.0: drop 72_all_PR111600-genemit-Distribute-evenly-to-files.patch
Now merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...111600-genemit-Distribute-evenly-to-files.patch | 194 ---------------------
 15.0.0/gentoo/README.history                       |   4 +
 2 files changed, 4 insertions(+), 194 deletions(-)
diff --git a/15.0.0/gentoo/72_all_PR111600-genemit-Distribute-evenly-to-files.patch b/15.0.0/gentoo/72_all_PR111600-genemit-Distribute-evenly-to-files.patch
deleted file mode 100644
index 287e082..0000000
--- a/15.0.0/gentoo/72_all_PR111600-genemit-Distribute-evenly-to-files.patch
+++ /dev/null
@@ -1,194 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/D5S1TZK05IYW.2D2RLLK7L1ZQ1@gmail.com/
-
-From 359fea7741c6c8f98239aa32f5c3b6f4a582567b Mon Sep 17 00:00:00 2001
-Message-ID: <359fea7741c6c8f98239aa32f5c3b6f4a582567b.1732312478.git.sam@gentoo.org>
-From: Robin Dapp <rdapp.gcc@gmail.com>
-Date: Thu, 21 Nov 2024 18:56:32 +0100
-Subject: [PATCH] genemit: Distribute evenly to files [PR111600].
-
-Hi,
-
-currently we distribute insn patterns in genemit, partitioning them
-by the number of patterns per file.  The first 100 into file 1, the
-next 100 into file 2, and so on.  Depending on the patterns this
-can lead to files of very uneven size.
-
-Similar to the genmatch split, this patch introduces a dynamic
-choose_output () which considers the size of the output files
-and selects the shortest one for the next pattern.
-
-Bootstrapped and regtested on x86 and power10, aarch64 running.
-Regtested on rv64gcv.
-
-gcc/ChangeLog:
-
-	PR target/111600
-
-* genemit.cc (handle_arg): Use files instead of filenames.
-	(main): Ditto.
-	* gensupport.cc (SIZED_BASED_CHUNKS): Define.
-	(choose_output): New function.
-	* gensupport.h (choose_output): Declare.
----
- gcc/genemit.cc    | 53 ++++++++++++++---------------------------------
- gcc/gensupport.cc | 33 +++++++++++++++++++++++++++++
- gcc/gensupport.h  |  1 +
- 3 files changed, 50 insertions(+), 37 deletions(-)
-
-diff --git a/gcc/genemit.cc b/gcc/genemit.cc
-index 5d3d10f5061a..518fb85ce8c8 100644
---- a/gcc/genemit.cc
-+++ b/gcc/genemit.cc
-@@ -905,14 +905,15 @@ from the machine description file `md'.  */\n\n");
-   fprintf (file, "#include \"target.h\"\n\n");
- }
- 
--auto_vec<const char *, 10> output_files;
-+auto_vec<FILE *, 10> output_files;
- 
- static bool
- handle_arg (const char *arg)
- {
-   if (arg[1] == 'O')
-     {
--      output_files.safe_push (&arg[2]);
-+      FILE *file = fopen (&arg[2], "w");
-+      output_files.safe_push (file);
-       return true;
-     }
-   return false;
-@@ -933,47 +934,21 @@ main (int argc, const char **argv)
-   /* Assign sequential codes to all entries in the machine description
-      in parallel with the tables in insn-output.cc.  */
- 
--  int npatterns = count_patterns ();
-   md_rtx_info info;
- 
--  bool to_stdout = false;
--  int npatterns_per_file = npatterns;
--  if (!output_files.is_empty ())
--    npatterns_per_file = npatterns / output_files.length () + 1;
--  else
--    to_stdout = true;
--
--  gcc_assert (npatterns_per_file > 1);
-+  if (output_files.is_empty ())
-+    output_files.safe_push (stdout);
- 
--  /* Reverse so we can pop the first-added element.  */
--  output_files.reverse ();
-+  for (auto f : output_files)
-+    print_header (f);
- 
--  int count = 0;
-   FILE *file = NULL;
-+  unsigned file_idx;
- 
-   /* Read the machine description.  */
-   while (read_md_rtx (&info))
-     {
--      if (count == 0 || count == npatterns_per_file)
--	{
--	  bool is_last = !to_stdout && output_files.is_empty ();
--	  if (file && !is_last)
--	    if (fclose (file) != 0)
--	      return FATAL_EXIT_CODE;
--
--	  if (!output_files.is_empty ())
--	    {
--	      const char *const filename = output_files.pop ();
--	      file = fopen (filename, "w");
--	    }
--	  else if (to_stdout)
--	    file = stdout;
--	  else
--	    break;
--
--	  print_header (file);
--	  count = 0;
--	}
-+      file = choose_output (output_files, file_idx);
- 
-       switch (GET_CODE (info.def))
- 	{
-@@ -999,10 +974,10 @@ main (int argc, const char **argv)
- 	default:
- 	  break;
- 	}
--
--      count++;
-     }
- 
-+  file = choose_output (output_files, file_idx);
-+
-   /* Write out the routines to add CLOBBERs to a pattern and say whether they
-      clobber a hard reg.  */
-   output_add_clobbers (&info, file);
-@@ -1015,5 +990,9 @@ main (int argc, const char **argv)
-       handle_overloaded_gen (oname, file);
-     }
- 
--  return (fclose (file) != 0 ? FATAL_EXIT_CODE : SUCCESS_EXIT_CODE);
-+  for (FILE *f : output_files)
-+    if (fclose (f) != 0)
-+      return FATAL_EXIT_CODE;
-+
-+  return SUCCESS_EXIT_CODE;
- }
-diff --git a/gcc/gensupport.cc b/gcc/gensupport.cc
-index 3a02132c8761..e0adf0c1bc54 100644
---- a/gcc/gensupport.cc
-+++ b/gcc/gensupport.cc
-@@ -3913,3 +3913,36 @@ find_optab (optab_pattern *p, const char *name)
-     }
-   return false;
- }
-+
-+/* Find the file to write into next.  We try to evenly distribute the contents
-+   over the different files.  */
-+
-+#define SIZED_BASED_CHUNKS 1
-+
-+FILE *
-+choose_output (const vec<FILE *> &parts, unsigned &idx)
-+{
-+  if (parts.length () == 0)
-+    gcc_unreachable ();
-+#ifdef SIZED_BASED_CHUNKS
-+  FILE *shortest = NULL;
-+  long min = 0;
-+  idx = 0;
-+  for (unsigned i = 0; i < parts.length (); i++)
-+    {
-+      FILE *part  = parts[i];
-+      long len = ftell (part);
-+      if (!shortest || min > len)
-+	{
-+	  shortest = part;
-+	  min = len;
-+	  idx = i;
-+       }
-+    }
-+  return shortest;
-+#else
-+  static int current_file;
-+  idx = current_file++ % parts.length ();
-+  return parts[idx];
-+#endif
-+}
-diff --git a/gcc/gensupport.h b/gcc/gensupport.h
-index b7a1da34518c..781c9e9ffcea 100644
---- a/gcc/gensupport.h
-+++ b/gcc/gensupport.h
-@@ -231,5 +231,6 @@ extern file_location get_file_location (rtx);
- extern const char *get_emit_function (rtx);
- extern bool needs_barrier_p (rtx);
- extern bool find_optab (optab_pattern *, const char *);
-+extern FILE *choose_output (const vec<FILE *> &, unsigned &);
- 
- #endif /* GCC_GENSUPPORT_H */
-
-base-commit: 76c202329458aad027ececc59d666e4995e3644e
--- 
-2.47.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 7a89c63..926d4de 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+??
+
+	- 72_all_PR111600-genemit-Distribute-evenly-to-files.patch
+
 28	25 November 2024
 
 	+ 72_all_PR111600-genemit-Distribute-evenly-to-files.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-27 17:42 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-27 17:42 UTC (permalink / raw
  To: gentoo-commits
commit:     ee2008a6cbb19d604b2cfa4e9c1eeb08e2488cf0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 27 17:42:31 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov 27 17:42:31 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ee2008a6
15.0.0: pull in genrecog split patch
I will see about backporting these (downstream) once they're all merged,
at least to 14.
Bug: https://gcc.gnu.org/PR111600
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...0-genrecog-Split-into-separate-partitions.patch | 1369 ++++++++++++++++++++
 1 file changed, 1369 insertions(+)
diff --git a/15.0.0/gentoo/72_all_PR111600-genrecog-Split-into-separate-partitions.patch b/15.0.0/gentoo/72_all_PR111600-genrecog-Split-into-separate-partitions.patch
new file mode 100644
index 0000000..07486e4
--- /dev/null
+++ b/15.0.0/gentoo/72_all_PR111600-genrecog-Split-into-separate-partitions.patch
@@ -0,0 +1,1369 @@
+From 1135970eb38c8f90db20c12cb4222e3a5214557e Mon Sep 17 00:00:00 2001
+Message-ID: <1135970eb38c8f90db20c12cb4222e3a5214557e.1732630692.git.sam@gentoo.org>
+From: Robin Dapp <rdapp.gcc@gmail.com>
+Date: Tue, 26 Nov 2024 14:44:17 +0100
+Subject: [PATCH] genrecog: Split into separate partitions [PR111600].
+
+Hi,
+
+this patch makes genrecog split its output into separate files (10 by
+default) in the same vein genemit does.  The changes are mostly
+mechanical again, changing printfs and puts to fprintf.
+As insn-recog.cc relies on being able to call other recog functions a
+header insn-recog.h is introduced that pre declares all of those.
+
+For simplicity the number of files is determined by (re-using)
+--with-insnemit-partitions.  Naming suggestions welcome :)
+
+Bootstrapped and regtested on x86 and power10, regtested on riscv.
+aarch64 bootstrap is currently blocked because of the
+"maybe uninitialized" issue discussed on IRC.
+
+Regards
+ Robin
+
+gcc/ChangeLog:
+
+* Makefile.in:  Add insn-recog split.
+	* configure.ac: Document that the number of insnemit partitions is
+	used for insn-recog as well.
+	* genconditions.cc (write_one_condition): Use fprintf.
+	* genpreds.cc (write_predicate_expr): Ditto.
+	(write_init_reg_class_start_regs): Ditto.
+	* genrecog.cc (write_header): Add header file to includes.
+	(printf_indent): Use fprintf.
+	(change_state): Ditto.
+	(print_code): Ditto.
+	(print_host_wide_int): Ditto.
+	(print_parameter_value): Ditto.
+	(print_test_rtx): Ditto.
+	(print_nonbool_test): Ditto.
+	(print_label_value): Ditto.
+	(print_test): Ditto.
+	(print_decision): Ditto.
+	(print_state): Ditto.
+	(print_subroutine_call): Ditto.
+	(print_acceptance): Ditto.
+	(print_subroutine_start): Ditto.
+	(print_pattern): Ditto.
+	(print_subroutine): Ditto.
+	(print_subroutine_group): Ditto.
+	(handle_arg): Add -O and -H for output and header file handling.
+	(main): Use callback.
+	* gentarget-def.cc (def_target_insn): Use fprintf.
+	* read-md.cc (md_reader::print_c_condition): Ditto.
+	* read-md.h (class md_reader): Ditto.
+---
+ gcc/Makefile.in      |  29 ++-
+ gcc/configure.ac     |   4 +-
+ gcc/genconditions.cc |   4 +-
+ gcc/genpreds.cc      |   4 +-
+ gcc/genrecog.cc      | 552 +++++++++++++++++++++++++------------------
+ gcc/gentarget-def.cc |   2 +-
+ gcc/read-md.cc       |   4 +-
+ gcc/read-md.h        |   2 +-
+ 8 files changed, 358 insertions(+), 243 deletions(-)
+
+diff --git a/gcc/Makefile.in b/gcc/Makefile.in
+index ead8d2eb094c..d301bef47003 100644
+--- a/gcc/Makefile.in
++++ b/gcc/Makefile.in
+@@ -239,6 +239,12 @@ INSNEMIT_SEQ_SRC = $(patsubst %, insn-emit-%.cc, $(INSNEMIT_SPLITS_SEQ))
+ INSNEMIT_SEQ_TMP = $(patsubst %, tmp-emit-%.cc, $(INSNEMIT_SPLITS_SEQ))
+ INSNEMIT_SEQ_O = $(patsubst %, insn-emit-%.o, $(INSNEMIT_SPLITS_SEQ))
+ 
++# Re-use the split number for insn-recog as well.
++INSNRECOG_SPLITS_SEQ = $(wordlist 1,$(NUM_INSNEMIT_SPLITS),$(one_to_9999))
++INSNRECOG_SEQ_SRC = $(patsubst %, insn-recog-%.cc, $(INSNRECOG_SPLITS_SEQ))
++INSNRECOG_SEQ_TMP = $(patsubst %, tmp-recog-%.cc, $(INSNRECOG_SPLITS_SEQ))
++INSNRECOG_SEQ_O = $(patsubst %, insn-recog-%.o, $(INSNRECOG_SPLITS_SEQ))
++
+ # These files are to have specific diagnostics suppressed, or are not to
+ # be subject to -Werror:
+ # flex output may yield harmless "no previous prototype" warnings
+@@ -1385,7 +1391,7 @@ OBJS = \
+ 	insn-output.o \
+ 	insn-peep.o \
+ 	insn-preds.o \
+-	insn-recog.o \
++	$(INSNRECOG_SEQ_O) \
+ 	insn-enums.o \
+ 	ggc-page.o \
+ 	adjust-alignment.o \
+@@ -1903,8 +1909,8 @@ TREECHECKING = @TREECHECKING@
+ FULL_DRIVER_NAME=$(target_noncanonical)-gcc-$(version)$(exeext)
+ 
+ MOSTLYCLEANFILES = insn-flags.h insn-config.h insn-codes.h \
+- insn-output.cc insn-recog.cc $(INSNEMIT_SEQ_SRC) \
+- insn-extract.cc insn-peep.cc \
++ insn-output.cc $(INSNRECOG_SEQ_SRC) insn-recog.h \
++ $(INSNEMIT_SEQ_SRC) insn-extract.cc insn-peep.cc \
+  insn-attr.h insn-attr-common.h insn-attrtab.cc insn-dfatab.cc \
+  insn-latencytab.cc insn-opinit.cc insn-opinit.h insn-preds.cc insn-constants.h \
+  tm-preds.h tm-constrs.h checksum-options $(GIMPLE_MATCH_PD_SEQ_SRC) \
+@@ -2671,7 +2677,8 @@ $(common_out_object_file): $(common_out_file)
+ # and compile them.
+ 
+ .PRECIOUS: insn-config.h insn-flags.h insn-codes.h insn-constants.h \
+-  $(INSNEMIT_SEQ_SRC) insn-recog.cc insn-extract.cc insn-output.cc \
++  $(INSNEMIT_SEQ_SRC) insn-recog.h $(INSNRECOG_SEQ_SRC) \
++  insn-extract.cc insn-output.cc \
+   insn-peep.cc insn-attr.h insn-attr-common.h insn-attrtab.cc \
+   insn-dfatab.cc insn-latencytab.cc insn-preds.cc \
+   $(GIMPLE_MATCH_PD_SEQ_SRC) $(GENERIC_MATCH_PD_SEQ_SRC) \
+@@ -2700,7 +2707,7 @@ simple_rtl_generated_h	= insn-attr.h insn-attr-common.h insn-codes.h \
+ 
+ simple_rtl_generated_c	= insn-automata.cc \
+ 			  insn-extract.cc insn-output.cc \
+-			  insn-peep.cc insn-recog.cc
++			  insn-peep.cc
+ 
+ simple_generated_h	= $(simple_rtl_generated_h) insn-constants.h
+ 
+@@ -2738,6 +2745,18 @@ s-tmp-emit: build/genemit$(build_exeext) $(MD_DEPS) insn-conditions.md
+ 	  insn-emit-$(id).cc;)
+ 	$(STAMP) s-tmp-emit
+ 
++# Same for genrecog.
++$(INSNRECOG_SEQ_SRC): s-tmp-recog; @true
++insn-recog.h: s-tmp-recog; @true
++s-tmp-recog: build/genrecog$(build_exeext) $(MD_DEPS) insn-conditions.md
++	$(RUN_GEN) build/genrecog$(build_exeext) $(md_file) insn-conditions.md \
++	  -Hinsn-recog.h \
++	  $(addprefix -O,${INSNRECOG_SEQ_TMP})
++	$(foreach id, $(INSNRECOG_SPLITS_SEQ), \
++	  $(SHELL) $(srcdir)/../move-if-change tmp-recog-$(id).cc \
++	  insn-recog-$(id).cc;)
++	$(STAMP) s-tmp-recog
++
+ # gencheck doesn't read the machine description, and the file produced
+ # doesn't use the insn-* convention.
+ 
+diff --git a/gcc/configure.ac b/gcc/configure.ac
+index c546432b2775..a0d9038ea595 100644
+--- a/gcc/configure.ac
++++ b/gcc/configure.ac
+@@ -913,10 +913,10 @@ fi
+ 
+ AC_SUBST(DEFAULT_MATCHPD_PARTITIONS)
+ 
+-# Specify the number of splits of insn-emit.cc to generate.
++# Specify the number of splits of insn-emit.cc and insn-recog.cc to generate.
+ AC_ARG_WITH(insnemit-partitions,
+ [AS_HELP_STRING([--with-insnemit-partitions=num],
+-[Set the number of partitions of insn-emit.cc for genemit to create. [default=10]])],
++[Set the number of partitions of insn-emit.cc for genemit and genrecog to create. [default=10]])],
+ [DEFAULT_INSNEMIT_PARTITIONS="$with_insnemit_partitions"], [DEFAULT_INSNEMIT_PARTITIONS=10])
+ if (test $DEFAULT_INSNEMIT_PARTITIONS -lt 1); then
+   AC_MSG_ERROR(m4_normalize([
+diff --git a/gcc/genconditions.cc b/gcc/genconditions.cc
+index 13963dc3ff46..9da460893d52 100644
+--- a/gcc/genconditions.cc
++++ b/gcc/genconditions.cc
+@@ -141,9 +141,9 @@ write_one_condition (void **slot, void * ARG_UNUSED (dummy))
+     }
+ 
+   fputs ("\",\n    __builtin_constant_p ", stdout);
+-  rtx_reader_ptr->print_c_condition (test->expr);
++  rtx_reader_ptr->print_c_condition (stdout, test->expr);
+   fputs ("\n    ? (int) ", stdout);
+-  rtx_reader_ptr->print_c_condition (test->expr);
++  rtx_reader_ptr->print_c_condition (stdout, test->expr);
+   fputs ("\n    : -1 },\n", stdout);
+   return 1;
+ }
+diff --git a/gcc/genpreds.cc b/gcc/genpreds.cc
+index 55d149e8a404..b8f3bf279d97 100644
+--- a/gcc/genpreds.cc
++++ b/gcc/genpreds.cc
+@@ -538,7 +538,7 @@ write_predicate_expr (rtx exp)
+       break;
+ 
+     case MATCH_TEST:
+-      rtx_reader_ptr->print_c_condition (XSTR (exp, 0));
++      rtx_reader_ptr->print_c_condition (stdout, XSTR (exp, 0));
+       break;
+ 
+     default:
+@@ -1344,7 +1344,7 @@ write_init_reg_class_start_regs ()
+       for (unsigned int i = 0; i < register_filters.length (); ++i)
+ 	{
+ 	  printf ("      if (");
+-	  rtx_reader_ptr->print_c_condition (register_filters[i]);
++	  rtx_reader_ptr->print_c_condition (stdout, register_filters[i]);
+ 	  printf (")\n"
+ 		  "        SET_HARD_REG_BIT (%s[%d], regno);\n",
+ 		  "this_target_constraints->register_filters", i);
+diff --git a/gcc/genrecog.cc b/gcc/genrecog.cc
+index ba09ec3b6005..7f7ca728bbe0 100644
+--- a/gcc/genrecog.cc
++++ b/gcc/genrecog.cc
+@@ -4255,9 +4255,9 @@ match_pattern (state *s, md_rtx_info *info, rtx pattern,
+ /* Begin the output file.  */
+ 
+ static void
+-write_header (void)
++write_header (FILE *f, const char *header_filename)
+ {
+-  puts ("\
++  fprintf (f, "%s", "\
+ /* Generated automatically by the program `genrecog' from the target\n\
+    machine description file.  */\n\
+ \n\
+@@ -4281,10 +4281,12 @@ write_header (void)
+ #include \"diagnostic-core.h\"\n\
+ #include \"reload.h\"\n\
+ #include \"regs.h\"\n\
+-#include \"tm-constrs.h\"\n\
+-\n");
++#include \"tm-constrs.h\"\n");
+ 
+-  puts ("\n\
++  fprintf (f, "#include \"%s\"\n", header_filename);
++  fprintf (f, "%s", "\n");
++
++  fprintf (f, "%s", "\n\
+ /* `recog' contains a decision tree that recognizes whether the rtx\n\
+    X0 is a valid instruction.\n\
+ \n\
+@@ -4293,19 +4295,19 @@ write_header (void)
+    pattern that matched.  This is the same as the order in the machine\n\
+    description of the entry that matched.  This number can be used as an\n\
+    index into `insn_data' and other tables.\n");
+-  puts ("\
++  fprintf (f, "%s", "\
+    The third parameter to recog is an optional pointer to an int.  If\n\
+    present, recog will accept a pattern if it matches except for missing\n\
+    CLOBBER expressions at the end.  In that case, the value pointed to by\n\
+    the optional pointer will be set to the number of CLOBBERs that need\n\
+    to be added (it should be initialized to zero by the caller).  If it");
+-  puts ("\
++  fprintf (f, "%s", "\
+    is set nonzero, the caller should allocate a PARALLEL of the\n\
+    appropriate size, copy the initial entries, and call add_clobbers\n\
+    (found in insn-emit.cc) to fill in the CLOBBERs.\n\
+ ");
+ 
+-  puts ("\n\
++  fprintf (f, "%s", "\n\
+    The function split_insns returns 0 if the rtl could not\n\
+    be split or the split rtl as an INSN list if it can be.\n\
+ \n\
+@@ -4463,13 +4465,13 @@ test_position_available_p (output_state *os, const rtx_test &test)
+ 
+ /* Like printf, but print INDENT spaces at the beginning.  */
+ 
+-static void ATTRIBUTE_PRINTF_2
+-printf_indent (unsigned int indent, const char *format, ...)
++static void ATTRIBUTE_PRINTF_3
++printf_indent (FILE *f, unsigned int indent, const char *format, ...)
+ {
+   va_list ap;
+   va_start (ap, format);
+-  printf ("%*s", indent, "");
+-  vprintf (format, ap);
++  fprintf (f, "%*s", indent, "");
++  vfprintf (f, format, ap);
+   va_end (ap);
+ }
+ 
+@@ -4478,7 +4480,7 @@ printf_indent (unsigned int indent, const char *format, ...)
+    OS with the new state.  */
+ 
+ static void
+-change_state (output_state *os, position *pos, unsigned int indent)
++change_state (FILE *f, output_state *os, position *pos, unsigned int indent)
+ {
+   unsigned int var = os->id_to_var[pos->id];
+   gcc_assert (var < os->var_to_id.length () && os->var_to_id[var] == pos->id);
+@@ -4487,19 +4489,19 @@ change_state (output_state *os, position *pos, unsigned int indent)
+   switch (pos->type)
+     {
+     case POS_PEEP2_INSN:
+-      printf_indent (indent, "x%d = PATTERN (peep2_next_insn (%d));\n",
++      printf_indent (f, indent, "x%d = PATTERN (peep2_next_insn (%d));\n",
+ 		     var, pos->arg);
+       break;
+ 
+     case POS_XEXP:
+-      change_state (os, pos->base, indent);
+-      printf_indent (indent, "x%d = XEXP (x%d, %d);\n",
++      change_state (f, os, pos->base, indent);
++      printf_indent (f, indent, "x%d = XEXP (x%d, %d);\n",
+ 		     var, os->id_to_var[pos->base->id], pos->arg);
+       break;
+ 
+     case POS_XVECEXP0:
+-      change_state (os, pos->base, indent);
+-      printf_indent (indent, "x%d = XVECEXP (x%d, 0, %d);\n",
++      change_state (f, os, pos->base, indent);
++      printf_indent (f, indent, "x%d = XVECEXP (x%d, 0, %d);\n",
+ 		     var, os->id_to_var[pos->base->id], pos->arg);
+       break;
+     }
+@@ -4510,11 +4512,11 @@ change_state (output_state *os, position *pos, unsigned int indent)
+    the name.  */
+ 
+ static void
+-print_code (enum rtx_code code)
++print_code (FILE *f, enum rtx_code code)
+ {
+   const char *p;
+   for (p = GET_RTX_NAME (code); *p; p++)
+-    putchar (TOUPPER (*p));
++    fprintf (f, "%c", TOUPPER (*p));
+ }
+ 
+ /* Emit a uint64_t as an integer constant expression.  We need to take
+@@ -4522,22 +4524,22 @@ print_code (enum rtx_code code)
+    warnings in the resulting code.  */
+ 
+ static void
+-print_host_wide_int (uint64_t val)
++print_host_wide_int (FILE *f, uint64_t val)
+ {
+   uint64_t min = uint64_t (1) << (HOST_BITS_PER_WIDE_INT - 1);
+   if (val == min)
+-    printf ("(" HOST_WIDE_INT_PRINT_DEC_C " - 1)", val + 1);
++    fprintf (f, "(" HOST_WIDE_INT_PRINT_DEC_C " - 1)", val + 1);
+   else
+-    printf (HOST_WIDE_INT_PRINT_DEC_C, val);
++    fprintf (f, HOST_WIDE_INT_PRINT_DEC_C, val);
+ }
+ 
+ /* Print the C expression for actual parameter PARAM.  */
+ 
+ static void
+-print_parameter_value (const parameter ¶m)
++print_parameter_value (FILE *f, const parameter ¶m)
+ {
+   if (param.is_param)
+-    printf ("i%d", (int) param.value + 1);
++    fprintf (f, "i%d", (int) param.value + 1);
+   else
+     switch (param.type)
+       {
+@@ -4546,23 +4548,23 @@ print_parameter_value (const parameter ¶m)
+ 	break;
+ 
+       case parameter::CODE:
+-	print_code ((enum rtx_code) param.value);
++	print_code (f, (enum rtx_code) param.value);
+ 	break;
+ 
+       case parameter::MODE:
+-	printf ("E_%smode", GET_MODE_NAME ((machine_mode) param.value));
++	fprintf (f, "E_%smode", GET_MODE_NAME ((machine_mode) param.value));
+ 	break;
+ 
+       case parameter::INT:
+-	printf ("%d", (int) param.value);
++	fprintf (f, "%d", (int) param.value);
+ 	break;
+ 
+       case parameter::UINT:
+-	printf ("%u", (unsigned int) param.value);
++	fprintf (f, "%u", (unsigned int) param.value);
+ 	break;
+ 
+       case parameter::WIDE_INT:
+-	print_host_wide_int (param.value);
++	print_host_wide_int (f, param.value);
+ 	break;
+       }
+ }
+@@ -4570,90 +4572,90 @@ print_parameter_value (const parameter ¶m)
+ /* Print the C expression for the rtx tested by TEST.  */
+ 
+ static void
+-print_test_rtx (output_state *os, const rtx_test &test)
++print_test_rtx (FILE *f, output_state *os, const rtx_test &test)
+ {
+   if (test.pos_operand >= 0)
+-    printf ("operands[%d]", test.pos_operand);
++    fprintf (f, "operands[%d]", test.pos_operand);
+   else
+-    printf ("x%d", os->id_to_var[test.pos->id]);
++    fprintf (f, "x%d", os->id_to_var[test.pos->id]);
+ }
+ 
+ /* Print the C expression for non-boolean test TEST.  */
+ 
+ static void
+-print_nonbool_test (output_state *os, const rtx_test &test)
++print_nonbool_test (FILE *f, output_state *os, const rtx_test &test)
+ {
+   switch (test.kind)
+     {
+     case rtx_test::CODE:
+-      printf ("GET_CODE (");
+-      print_test_rtx (os, test);
+-      printf (")");
++      fprintf (f, "GET_CODE (");
++      print_test_rtx (f, os, test);
++      fprintf (f, ")");
+       break;
+ 
+     case rtx_test::MODE:
+-      printf ("GET_MODE (");
+-      print_test_rtx (os, test);
+-      printf (")");
++      fprintf (f, "GET_MODE (");
++      print_test_rtx (f, os, test);
++      fprintf (f, ")");
+       break;
+ 
+     case rtx_test::VECLEN:
+-      printf ("XVECLEN (");
+-      print_test_rtx (os, test);
+-      printf (", 0)");
++      fprintf (f, "XVECLEN (");
++      print_test_rtx (f, os, test);
++      fprintf (f, ", 0)");
+       break;
+ 
+     case rtx_test::INT_FIELD:
+-      printf ("XINT (");
+-      print_test_rtx (os, test);
+-      printf (", %d)", test.u.opno);
++      fprintf (f, "XINT (");
++      print_test_rtx (f, os, test);
++      fprintf (f, ", %d)", test.u.opno);
+       break;
+ 
+     case rtx_test::REGNO_FIELD:
+-      printf ("REGNO (");
+-      print_test_rtx (os, test);
+-      printf (")");
++      fprintf (f, "REGNO (");
++      print_test_rtx (f, os, test);
++      fprintf (f, ")");
+       break;
+ 
+     case rtx_test::SUBREG_FIELD:
+-      printf ("SUBREG_BYTE (");
+-      print_test_rtx (os, test);
+-      printf (")");
++      fprintf (f, "SUBREG_BYTE (");
++      print_test_rtx (f, os, test);
++      fprintf (f, ")");
+       break;
+ 
+     case rtx_test::WIDE_INT_FIELD:
+-      printf ("XWINT (");
+-      print_test_rtx (os, test);
+-      printf (", %d)", test.u.opno);
++      fprintf (f, "XWINT (");
++      print_test_rtx (f, os, test);
++      fprintf (f, ", %d)", test.u.opno);
+       break;
+ 
+     case rtx_test::PATTERN:
+       {
+ 	pattern_routine *routine = test.u.pattern->routine;
+-	printf ("pattern%d (", routine->pattern_id);
++	fprintf (f, "pattern%d (", routine->pattern_id);
+ 	const char *sep = "";
+ 	if (test.pos)
+ 	  {
+-	    print_test_rtx (os, test);
++	    print_test_rtx (f, os, test);
+ 	    sep = ", ";
+ 	  }
+ 	if (routine->insn_p)
+ 	  {
+-	    printf ("%sinsn", sep);
++	    fprintf (f, "%sinsn", sep);
+ 	    sep = ", ";
+ 	  }
+ 	if (routine->pnum_clobbers_p)
+ 	  {
+-	    printf ("%spnum_clobbers", sep);
++	    fprintf (f, "%spnum_clobbers", sep);
+ 	    sep = ", ";
+ 	  }
+ 	for (unsigned int i = 0; i < test.u.pattern->params.length (); ++i)
+ 	  {
+-	    fputs (sep, stdout);
+-	    print_parameter_value (test.u.pattern->params[i]);
++	    fprintf (f, "%s\n", sep);
++	    print_parameter_value (f, test.u.pattern->params[i]);
+ 	    sep = ", ";
+ 	  }
+-	printf (")");
++	fprintf (f, ")");
+ 	break;
+       }
+ 
+@@ -4674,10 +4676,11 @@ print_nonbool_test (output_state *os, const rtx_test &test)
+    decision performs TEST.  Print the C code for the label.  */
+ 
+ static void
+-print_label_value (const rtx_test &test, bool is_param, uint64_t value)
++print_label_value (FILE *f, const rtx_test &test, bool is_param,
++		   uint64_t value)
+ {
+-  print_parameter_value (parameter (transition_parameter_type (test.kind),
+-				    is_param, value));
++  print_parameter_value (f, parameter (transition_parameter_type (test.kind),
++				       is_param, value));
+ }
+ 
+ /* If IS_PARAM, print code to compare TEST with the C variable i<VALUE+1>.
+@@ -4685,7 +4688,7 @@ print_label_value (const rtx_test &test, bool is_param, uint64_t value)
+    Test for inequality if INVERT_P, otherwise test for equality.  */
+ 
+ static void
+-print_test (output_state *os, const rtx_test &test, bool is_param,
++print_test (FILE *f, output_state *os, const rtx_test &test, bool is_param,
+ 	    uint64_t value, bool invert_p)
+ {
+   switch (test.kind)
+@@ -4698,71 +4701,71 @@ print_test (output_state *os, const rtx_test &test, bool is_param,
+     case rtx_test::INT_FIELD:
+     case rtx_test::WIDE_INT_FIELD:
+     case rtx_test::PATTERN:
+-      print_nonbool_test (os, test);
+-      printf (" %s ", invert_p ? "!=" : "==");
+-      print_label_value (test, is_param, value);
++      print_nonbool_test (f, os, test);
++      fprintf (f, " %s ", invert_p ? "!=" : "==");
++      print_label_value (f, test, is_param, value);
+       break;
+ 
+     case rtx_test::SUBREG_FIELD:
+-      printf ("%s (", invert_p ? "maybe_ne" : "known_eq");
+-      print_nonbool_test (os, test);
+-      printf (", ");
+-      print_label_value (test, is_param, value);
+-      printf (")");
++      fprintf (f, "%s (", invert_p ? "maybe_ne" : "known_eq");
++      print_nonbool_test (f, os, test);
++      fprintf (f, ", ");
++      print_label_value (f, test, is_param, value);
++      fprintf (f, ")");
+       break;
+ 
+     case rtx_test::SAVED_CONST_INT:
+       gcc_assert (!is_param && value == 1);
+-      print_test_rtx (os, test);
+-      printf (" %s const_int_rtx[MAX_SAVED_CONST_INT + ",
+-	      invert_p ? "!=" : "==");
+-      print_parameter_value (parameter (parameter::INT,
+-					test.u.integer.is_param,
+-					test.u.integer.value));
+-      printf ("]");
++      print_test_rtx (f, os, test);
++      fprintf (f, " %s const_int_rtx[MAX_SAVED_CONST_INT + ",
++	       invert_p ? "!=" : "==");
++      print_parameter_value (f, parameter (parameter::INT,
++					   test.u.integer.is_param,
++					   test.u.integer.value));
++      fprintf (f, "]");
+       break;
+ 
+     case rtx_test::PEEP2_COUNT:
+       gcc_assert (!is_param && value == 1);
+-      printf ("peep2_current_count %s %d", invert_p ? "<" : ">=",
+-	      test.u.min_len);
++      fprintf (f, "peep2_current_count %s %d", invert_p ? "<" : ">=",
++	       test.u.min_len);
+       break;
+ 
+     case rtx_test::VECLEN_GE:
+       gcc_assert (!is_param && value == 1);
+-      printf ("XVECLEN (");
+-      print_test_rtx (os, test);
+-      printf (", 0) %s %d", invert_p ? "<" : ">=", test.u.min_len);
++      fprintf (f, "XVECLEN (");
++      print_test_rtx (f, os, test);
++      fprintf (f, ", 0) %s %d", invert_p ? "<" : ">=", test.u.min_len);
+       break;
+ 
+     case rtx_test::PREDICATE:
+       gcc_assert (!is_param && value == 1);
+-      printf ("%s%s (", invert_p ? "!" : "", test.u.predicate.data->name);
+-      print_test_rtx (os, test);
+-      printf (", ");
+-      print_parameter_value (parameter (parameter::MODE,
+-					test.u.predicate.mode_is_param,
+-					test.u.predicate.mode));
+-      printf (")");
++      fprintf (f, "%s%s (", invert_p ? "!" : "", test.u.predicate.data->name);
++      print_test_rtx (f, os, test);
++      fprintf (f, ", ");
++      print_parameter_value (f, parameter (parameter::MODE,
++					   test.u.predicate.mode_is_param,
++					   test.u.predicate.mode));
++      fprintf (f, ")");
+       break;
+ 
+     case rtx_test::DUPLICATE:
+       gcc_assert (!is_param && value == 1);
+-      printf ("%srtx_equal_p (", invert_p ? "!" : "");
+-      print_test_rtx (os, test);
+-      printf (", operands[%d])", test.u.opno);
++      fprintf (f, "%srtx_equal_p (", invert_p ? "!" : "");
++      print_test_rtx (f, os, test);
++      fprintf (f, ", operands[%d])", test.u.opno);
+       break;
+ 
+     case rtx_test::HAVE_NUM_CLOBBERS:
+       gcc_assert (!is_param && value == 1);
+-      printf ("pnum_clobbers %s NULL", invert_p ? "==" : "!=");
++      fprintf (f, "pnum_clobbers %s NULL", invert_p ? "==" : "!=");
+       break;
+ 
+     case rtx_test::C_TEST:
+       gcc_assert (!is_param && value == 1);
+       if (invert_p)
+-	printf ("!");
+-      rtx_reader_ptr->print_c_condition (test.u.string);
++	fprintf (f, "!");
++      rtx_reader_ptr->print_c_condition (f, test.u.string);
+       break;
+ 
+     case rtx_test::ACCEPT:
+@@ -4771,7 +4774,7 @@ print_test (output_state *os, const rtx_test &test, bool is_param,
+     }
+ }
+ 
+-static exit_state print_decision (output_state *, decision *,
++static exit_state print_decision (FILE *f, output_state *, decision *,
+ 				  unsigned int, bool);
+ 
+ /* Print code to perform S, indent each line by INDENT spaces.
+@@ -4779,14 +4782,15 @@ static exit_state print_decision (output_state *, decision *,
+    if the state fails then the entire routine fails.  */
+ 
+ static exit_state
+-print_state (output_state *os, state *s, unsigned int indent, bool is_final)
++print_state (FILE *f, output_state *os, state *s, unsigned int indent,
++	     bool is_final)
+ {
+   exit_state es = ES_FALLTHROUGH;
+   for (decision *d = s->first; d; d = d->next)
+-    es = print_decision (os, d, indent, is_final && !d->next);
++    es = print_decision (f, os, d, indent, is_final && !d->next);
+   if (es != ES_RETURNED && is_final)
+     {
+-      printf_indent (indent, "return %s;\n", get_failure_return (os->type));
++      printf_indent (f, indent, "return %s;\n", get_failure_return (os->type));
+       es = ES_RETURNED;
+     }
+   return es;
+@@ -4797,7 +4801,7 @@ print_state (output_state *os, state *s, unsigned int indent, bool is_final)
+    match.  */
+ 
+ static const char *
+-print_subroutine_call (const acceptance_type &acceptance)
++print_subroutine_call (FILE *f, const acceptance_type &acceptance)
+ {
+   switch (acceptance.type)
+     {
+@@ -4805,17 +4809,17 @@ print_subroutine_call (const acceptance_type &acceptance)
+       gcc_unreachable ();
+ 
+     case RECOG:
+-      printf ("recog_%d (x1, insn, pnum_clobbers)",
+-	      acceptance.u.subroutine_id);
++      fprintf (f, "recog_%d (x1, insn, pnum_clobbers)",
++	       acceptance.u.subroutine_id);
+       return ">= 0";
+ 
+     case SPLIT:
+-      printf ("split_%d (x1, insn)", acceptance.u.subroutine_id);
++      fprintf (f, "split_%d (x1, insn)", acceptance.u.subroutine_id);
+       return "!= NULL_RTX";
+ 
+     case PEEPHOLE2:
+-      printf ("peephole2_%d (x1, insn, pmatch_len_)",
+-	      acceptance.u.subroutine_id);
++      fprintf (f, "peephole2_%d (x1, insn, pmatch_len_)",
++	       acceptance.u.subroutine_id);
+       return "!= NULL_RTX";
+     }
+   gcc_unreachable ();
+@@ -4825,63 +4829,65 @@ print_subroutine_call (const acceptance_type &acceptance)
+    INDENT and IS_FINAL are as for print_state.  */
+ 
+ static exit_state
+-print_acceptance (const acceptance_type &acceptance, unsigned int indent,
+-		  bool is_final)
++print_acceptance (FILE *f, const acceptance_type &acceptance,
++		  unsigned int indent, bool is_final)
+ {
+   if (acceptance.partial_p)
+     {
+       /* Defer the rest of the match to a subroutine.  */
+       if (is_final)
+ 	{
+-	  printf_indent (indent, "return ");
+-	  print_subroutine_call (acceptance);
+-	  printf (";\n");
++	  printf_indent (f, indent, "return ");
++	  print_subroutine_call (f, acceptance);
++	  fprintf (f, ";\n");
+ 	  return ES_RETURNED;
+ 	}
+       else
+ 	{
+-	  printf_indent (indent, "res = ");
+-	  const char *res_test = print_subroutine_call (acceptance);
+-	  printf (";\n");
+-	  printf_indent (indent, "if (res %s)\n", res_test);
+-	  printf_indent (indent + 2, "return res;\n");
++	  printf_indent (f, indent, "res = ");
++	  const char *res_test = print_subroutine_call (f, acceptance);
++	  fprintf (f, ";\n");
++	  printf_indent (f, indent, "if (res %s)\n", res_test);
++	  printf_indent (f, indent + 2, "return res;\n");
+ 	  return ES_FALLTHROUGH;
+ 	}
+     }
+   switch (acceptance.type)
+     {
+     case SUBPATTERN:
+-      printf_indent (indent, "return %d;\n", acceptance.u.full.code);
++      printf_indent (f, indent, "return %d;\n", acceptance.u.full.code);
+       return ES_RETURNED;
+ 
+     case RECOG:
+       if (acceptance.u.full.u.num_clobbers != 0)
+-	printf_indent (indent, "*pnum_clobbers = %d;\n",
++	printf_indent (f, indent, "*pnum_clobbers = %d;\n",
+ 		       acceptance.u.full.u.num_clobbers);
+-      printf_indent (indent, "return %d; /* %s */\n", acceptance.u.full.code,
++      printf_indent (f, indent, "return %d; /* %s */\n", acceptance.u.full.code,
+ 		     get_insn_name (acceptance.u.full.code));
+       return ES_RETURNED;
+ 
+     case SPLIT:
+-      printf_indent (indent, "return gen_split_%d (insn, operands);\n",
++      printf_indent (f, indent, "return gen_split_%d (insn, operands);\n",
+ 		     acceptance.u.full.code);
+       return ES_RETURNED;
+ 
+     case PEEPHOLE2:
+-      printf_indent (indent, "*pmatch_len_ = %d;\n",
++      printf_indent (f, indent, "*pmatch_len_ = %d;\n",
+ 		     acceptance.u.full.u.match_len);
+       if (is_final)
+ 	{
+-	  printf_indent (indent, "return gen_peephole2_%d (insn, operands);\n",
++	  printf_indent (f, indent,
++			 "return gen_peephole2_%d (insn, operands);\n",
+ 			 acceptance.u.full.code);
+ 	  return ES_RETURNED;
+ 	}
+       else
+ 	{
+-	  printf_indent (indent, "res = gen_peephole2_%d (insn, operands);\n",
++	  printf_indent (f,
++			 indent, "res = gen_peephole2_%d (insn, operands);\n",
+ 			 acceptance.u.full.code);
+-	  printf_indent (indent, "if (res != NULL_RTX)\n");
+-	  printf_indent (indent + 2, "return res;\n");
++	  printf_indent (f, indent, "if (res != NULL_RTX)\n");
++	  printf_indent (f, indent + 2, "return res;\n");
+ 	  return ES_FALLTHROUGH;
+ 	}
+     }
+@@ -4891,7 +4897,7 @@ print_acceptance (const acceptance_type &acceptance, unsigned int indent,
+ /* Print code to perform D.  INDENT and IS_FINAL are as for print_state.  */
+ 
+ static exit_state
+-print_decision (output_state *os, decision *d, unsigned int indent,
++print_decision (FILE *f, output_state *os, decision *d, unsigned int indent,
+ 		bool is_final)
+ {
+   uint64_t label;
+@@ -4900,7 +4906,7 @@ print_decision (output_state *os, decision *d, unsigned int indent,
+   /* Make sure the rtx under test is available either in operands[] or
+      in an xN variable.  */
+   if (d->test.pos && d->test.pos_operand < 0)
+-    change_state (os, d->test.pos, indent);
++    change_state (f, os, d->test.pos, indent);
+ 
+   /* Look for cases where a pattern routine P1 calls another pattern routine
+      P2 and where P1 returns X + BASE whenever P2 returns X.  If IS_FINAL
+@@ -4924,32 +4930,32 @@ print_decision (output_state *os, decision *d, unsigned int indent,
+     {
+       if (is_final && base == 0)
+ 	{
+-	  printf_indent (indent, "return ");
+-	  print_nonbool_test (os, d->test);
+-	  printf ("; /* [-1, %d] */\n", count - 1);
++	  printf_indent (f, indent, "return ");
++	  print_nonbool_test (f, os, d->test);
++	  fprintf (f, "; /* [-1, %d] */\n", count - 1);
+ 	  return ES_RETURNED;
+ 	}
+       else
+ 	{
+-	  printf_indent (indent, "res = ");
+-	  print_nonbool_test (os, d->test);
+-	  printf (";\n");
+-	  printf_indent (indent, "if (res >= 0)\n");
+-	  printf_indent (indent + 2, "return res");
++	  printf_indent (f, indent, "res = ");
++	  print_nonbool_test (f, os, d->test);
++	  fprintf (f, ";\n");
++	  printf_indent (f, indent, "if (res >= 0)\n");
++	  printf_indent (f, indent + 2, "return res");
+ 	  if (base != 0)
+-	    printf (" + %d", base);
+-	  printf ("; /* [%d, %d] */\n", base, base + count - 1);
++	    fprintf (f, " + %d", base);
++	  fprintf (f, "; /* [%d, %d] */\n", base, base + count - 1);
+ 	  return ES_FALLTHROUGH;
+ 	}
+     }
+   else if (d->test.kind == rtx_test::ACCEPT)
+-    return print_acceptance (d->test.u.acceptance, indent, is_final);
++    return print_acceptance (f, d->test.u.acceptance, indent, is_final);
+   else if (d->test.kind == rtx_test::SET_OP)
+     {
+-      printf_indent (indent, "operands[%d] = ", d->test.u.opno);
+-      print_test_rtx (os, d->test);
+-      printf (";\n");
+-      return print_state (os, d->singleton ()->to, indent, is_final);
++      printf_indent (f, indent, "operands[%d] = ", d->test.u.opno);
++      print_test_rtx (f, os, d->test);
++      fprintf (f, ";\n");
++      return print_state (f, os, d->singleton ()->to, indent, is_final);
+     }
+   /* Handle decisions with a single transition and a single transition
+      label.  */
+@@ -4957,13 +4963,13 @@ print_decision (output_state *os, decision *d, unsigned int indent,
+     {
+       transition *trans = d->singleton ();
+       if (mark_optional_transitions_p && trans->optional)
+-	printf_indent (indent, "/* OPTIONAL IF */\n");
++	printf_indent (f, indent, "/* OPTIONAL IF */\n");
+ 
+       /* Print the condition associated with TRANS.  Invert it if IS_FINAL,
+ 	 so that we return immediately on failure and fall through on
+ 	 success.  */
+-      printf_indent (indent, "if (");
+-      print_test (os, d->test, trans->is_param, label, is_final);
++      printf_indent (f, indent, "if (");
++      print_test (f, os, d->test, trans->is_param, label, is_final);
+ 
+       /* Look for following states that would be handled by this code
+ 	 on recursion.  If they don't need any preparatory statements,
+@@ -4979,13 +4985,13 @@ print_decision (output_state *os, decision *d, unsigned int indent,
+ 	      || !test_position_available_p (os, d->test))
+ 	    break;
+ 	  trans = d->first;
+-	  printf ("\n");
++	  fprintf (f, "\n");
+ 	  if (mark_optional_transitions_p && trans->optional)
+-	    printf_indent (indent + 4, "/* OPTIONAL IF */\n");
+-	  printf_indent (indent + 4, "%s ", is_final ? "||" : "&&");
+-	  print_test (os, d->test, trans->is_param, label, is_final);
++	    printf_indent (f, indent + 4, "/* OPTIONAL IF */\n");
++	  printf_indent (f, indent + 4, "%s ", is_final ? "||" : "&&");
++	  print_test (f, os, d->test, trans->is_param, label, is_final);
+ 	}
+-      printf (")\n");
++      fprintf (f, ")\n");
+ 
+       /* Print the conditional code with INDENT + 2 and the fallthrough
+ 	 code with indent INDENT.  */
+@@ -4994,9 +5000,9 @@ print_decision (output_state *os, decision *d, unsigned int indent,
+ 	{
+ 	  /* We inverted the condition above, so return failure in the
+ 	     "if" body and fall through to the target of the transition.  */
+-	  printf_indent (indent + 2, "return %s;\n",
++	  printf_indent (f, indent + 2, "return %s;\n",
+ 			 get_failure_return (os->type));
+-	  return print_state (os, to, indent, is_final);
++	  return print_state (f, os, to, indent, is_final);
+ 	}
+       else if (to->singleton ()
+ 	       && to->first->test.kind == rtx_test::ACCEPT
+@@ -5004,7 +5010,7 @@ print_decision (output_state *os, decision *d, unsigned int indent,
+ 	{
+ 	  /* The target of the transition is a simple "return" statement.
+ 	     It doesn't need any braces and doesn't fall through.  */
+-	  if (print_acceptance (to->first->test.u.acceptance,
++	  if (print_acceptance (f, to->first->test.u.acceptance,
+ 				indent + 2, true) != ES_RETURNED)
+ 	    gcc_unreachable ();
+ 	  return ES_FALLTHROUGH;
+@@ -5018,9 +5024,9 @@ print_decision (output_state *os, decision *d, unsigned int indent,
+ 	  auto_vec <bool, 32> old_seen;
+ 	  old_seen.safe_splice (os->seen_vars);
+ 
+-	  printf_indent (indent + 2, "{\n");
+-	  print_state (os, trans->to, indent + 4, is_final);
+-	  printf_indent (indent + 2, "}\n");
++	  printf_indent (f, indent + 2, "{\n");
++	  print_state (f, os, trans->to, indent + 4, is_final);
++	  printf_indent (f, indent + 2, "}\n");
+ 
+ 	  os->seen_vars.truncate (0);
+ 	  os->seen_vars.splice (old_seen);
+@@ -5030,48 +5036,48 @@ print_decision (output_state *os, decision *d, unsigned int indent,
+   else
+     {
+       /* Output the decision as a switch statement.  */
+-      printf_indent (indent, "switch (");
+-      print_nonbool_test (os, d->test);
+-      printf (")\n");
++      printf_indent (f, indent, "switch (");
++      print_nonbool_test (f, os, d->test);
++      fprintf (f, ")\n");
+ 
+       /* Each case statement starts with the same set of valid variables.
+ 	 These are also the only variables will be valid on fallthrough.  */
+       auto_vec <bool, 32> old_seen;
+       old_seen.safe_splice (os->seen_vars);
+ 
+-      printf_indent (indent + 2, "{\n");
++      printf_indent (f, indent + 2, "{\n");
+       for (transition *trans = d->first; trans; trans = trans->next)
+ 	{
+ 	  gcc_assert (!trans->is_param);
+ 	  if (mark_optional_transitions_p && trans->optional)
+-	    printf_indent (indent + 2, "/* OPTIONAL CASE */\n");
++	    printf_indent (f, indent + 2, "/* OPTIONAL CASE */\n");
+ 	  for (int_set::iterator j = trans->labels.begin ();
+ 	       j != trans->labels.end (); ++j)
+ 	    {
+-	      printf_indent (indent + 2, "case ");
+-	      print_label_value (d->test, trans->is_param, *j);
+-	      printf (":\n");
++	      printf_indent (f, indent + 2, "case ");
++	      print_label_value (f, d->test, trans->is_param, *j);
++	      fprintf (f, ":\n");
+ 	    }
+-	  if (print_state (os, trans->to, indent + 4, is_final))
++	  if (print_state (f, os, trans->to, indent + 4, is_final))
+ 	    {
+ 	      /* The state can fall through.  Add an explicit break.  */
+ 	      gcc_assert (!is_final);
+-	      printf_indent (indent + 4, "break;\n");
++	      printf_indent (f, indent + 4, "break;\n");
+ 	    }
+-	  printf ("\n");
++	  fprintf (f, "\n");
+ 
+ 	  /* Restore the original set of valid variables.  */
+ 	  os->seen_vars.truncate (0);
+ 	  os->seen_vars.splice (old_seen);
+ 	}
+       /* Add a default case.  */
+-      printf_indent (indent + 2, "default:\n");
++      printf_indent (f, indent + 2, "default:\n");
+       if (is_final)
+-	printf_indent (indent + 4, "return %s;\n",
++	printf_indent (f, indent + 4, "return %s;\n",
+ 		       get_failure_return (os->type));
+       else
+-	printf_indent (indent + 4, "break;\n");
+-      printf_indent (indent + 2, "}\n");
++	printf_indent (f, indent + 4, "break;\n");
++      printf_indent (f, indent + 2, "}\n");
+       return is_final ? ES_RETURNED : ES_FALLTHROUGH;
+     }
+ }
+@@ -5114,10 +5120,10 @@ assign_position_vars (output_state *os, state *s)
+    only ROOT's variable has a valid value.  */
+ 
+ static void
+-print_subroutine_start (output_state *os, state *s, position *root)
++print_subroutine_start (FILE *f, output_state *os, state *s, position *root)
+ {
+-  printf ("{\n  rtx * const operands ATTRIBUTE_UNUSED"
+-	  " = &recog_data.operand[0];\n");
++  fprintf (f, "{\n  rtx * const operands ATTRIBUTE_UNUSED"
++	   " = &recog_data.operand[0];\n");
+   os->var_to_id.truncate (0);
+   os->seen_vars.truncate (0);
+   if (root)
+@@ -5140,9 +5146,9 @@ print_subroutine_start (output_state *os, state *s, position *root)
+ 	{
+ 	  for (unsigned int i = 2; i < num_vars; ++i)
+ 	    /* Print 8 rtx variables to a line.  */
+-	    printf ("%s x%d",
++	    fprintf (f, "%s x%d",
+ 		    i == 2 ? "  rtx" : (i - 2) % 8 == 0 ? ";\n  rtx" : ",", i);
+-	  printf (";\n");
++	  fprintf (f, ";\n");
+ 	}
+ 
+       /* Say that x1 is valid and the rest aren't.  */
+@@ -5150,22 +5156,26 @@ print_subroutine_start (output_state *os, state *s, position *root)
+       os->seen_vars[1] = true;
+     }
+   if (os->type == SUBPATTERN || os->type == RECOG)
+-    printf ("  int res ATTRIBUTE_UNUSED;\n");
++    fprintf (f, "  int res ATTRIBUTE_UNUSED;\n");
+   else
+-    printf ("  rtx_insn *res ATTRIBUTE_UNUSED;\n");
++    fprintf (f, "  rtx_insn *res ATTRIBUTE_UNUSED;\n");
+ }
+ 
+ /* Output the definition of pattern routine ROUTINE.  */
+ 
+ static void
+-print_pattern (output_state *os, pattern_routine *routine)
++print_pattern (FILE *f, output_state *os, pattern_routine *routine,
++	       bool in_header = false)
+ {
+-  printf ("\nstatic int\npattern%d (", routine->pattern_id);
++  if (!in_header)
++    fprintf (f, "\nint\npattern%d (", routine->pattern_id);
++  else
++    fprintf (f, "\nextern int\npattern%d (", routine->pattern_id);
+   const char *sep = "";
+   /* Add the top-level rtx parameter, if any.  */
+   if (routine->pos)
+     {
+-      printf ("%srtx x1", sep);
++      fprintf (f, "%srtx x1", sep);
+       sep = ", ";
+     }
+   /* Add the optional parameters.  */
+@@ -5173,26 +5183,34 @@ print_pattern (output_state *os, pattern_routine *routine)
+     {
+       /* We can't easily tell whether a C condition actually reads INSN,
+ 	 so add an ATTRIBUTE_UNUSED just in case.  */
+-      printf ("%srtx_insn *insn ATTRIBUTE_UNUSED", sep);
++      fprintf (f, "%srtx_insn *insn ATTRIBUTE_UNUSED", sep);
+       sep = ", ";
+     }
+   if (routine->pnum_clobbers_p)
+     {
+-      printf ("%sint *pnum_clobbers", sep);
++      fprintf (f, "%sint *pnum_clobbers", sep);
+       sep = ", ";
+     }
+   /* Add the "i" parameters.  */
+   for (unsigned int i = 0; i < routine->param_types.length (); ++i)
+     {
+-      printf ("%s%s i%d", sep,
+-	      parameter_type_string (routine->param_types[i]), i + 1);
++      fprintf (f, "%s%s i%d", sep,
++	       parameter_type_string (routine->param_types[i]), i + 1);
+       sep = ", ";
+     }
+-  printf (")\n");
++
++  if (!in_header)
++    fprintf (f, ")\n");
++  else
++    {
++      fprintf (f, ");\n");
++      return;
++    }
++
+   os->type = SUBPATTERN;
+-  print_subroutine_start (os, routine->s, routine->pos);
+-  print_state (os, routine->s, 2, true);
+-  printf ("}\n");
++  print_subroutine_start (f, os, routine->s, routine->pos);
++  print_state (f, os, routine->s, 2, true);
++  fprintf (f, "}\n");
+ }
+ 
+ /* Output a routine of type TYPE that implements S.  PROC_ID is the
+@@ -5200,9 +5218,26 @@ print_pattern (output_state *os, pattern_routine *routine)
+    routine.  */
+ 
+ static void
+-print_subroutine (output_state *os, state *s, int proc_id)
+-{
+-  printf ("\n");
++print_subroutine (FILE *f, output_state *os, state *s, int proc_id,
++		  bool in_header = false)
++{
++  fprintf (f, "\n");
++  const char *specifier_ext = "extern";
++  const char *specifier_default = "";
++  const char *specifier;
++  if (!in_header)
++    specifier = specifier_default;
++  else
++    specifier = specifier_ext;
++
++  const char *end;
++  const char *end_default = "";
++  const char *end_header = ";";
++  if (!in_header)
++    end = end_default;
++  else
++    end = end_header;
++
+   switch (os->type)
+     {
+     case SUBPATTERN:
+@@ -5210,46 +5245,54 @@ print_subroutine (output_state *os, state *s, int proc_id)
+ 
+     case RECOG:
+       if (proc_id)
+-	printf ("static int\nrecog_%d", proc_id);
++	fprintf (f, "%s int\nrecog_%d", specifier, proc_id);
+       else
+-	printf ("int\nrecog");
+-      printf (" (rtx x1 ATTRIBUTE_UNUSED,\n"
+-	      "\trtx_insn *insn ATTRIBUTE_UNUSED,\n"
+-	      "\tint *pnum_clobbers ATTRIBUTE_UNUSED)\n");
++	fprintf (f, "%s int\nrecog", specifier);
++      fprintf (f, " (rtx x1 ATTRIBUTE_UNUSED,\n"
++	       "\trtx_insn *insn ATTRIBUTE_UNUSED,\n"
++	       "\tint *pnum_clobbers ATTRIBUTE_UNUSED)%s\n", end);
+       break;
+ 
+     case SPLIT:
+       if (proc_id)
+-	printf ("static rtx_insn *\nsplit_%d", proc_id);
++	fprintf (f, "%s rtx_insn *\nsplit_%d", specifier, proc_id);
+       else
+-	printf ("rtx_insn *\nsplit_insns");
+-      printf (" (rtx x1 ATTRIBUTE_UNUSED, rtx_insn *insn ATTRIBUTE_UNUSED)\n");
++	fprintf (f, "%s rtx_insn *\nsplit_insns", specifier);
++      fprintf (f, " (rtx x1 ATTRIBUTE_UNUSED, "
++		  "rtx_insn *insn ATTRIBUTE_UNUSED)%s\n", end);
+       break;
+ 
+     case PEEPHOLE2:
+       if (proc_id)
+-	printf ("static rtx_insn *\npeephole2_%d", proc_id);
++	fprintf (f, "%s rtx_insn *\npeephole2_%d", specifier, proc_id);
+       else
+-	printf ("rtx_insn *\npeephole2_insns");
+-      printf (" (rtx x1 ATTRIBUTE_UNUSED,\n"
+-	      "\trtx_insn *insn ATTRIBUTE_UNUSED,\n"
+-	      "\tint *pmatch_len_ ATTRIBUTE_UNUSED)\n");
++	fprintf (f, "%s rtx_insn *\npeephole2_insns", specifier);
++      fprintf (f, " (rtx x1 ATTRIBUTE_UNUSED,\n"
++	       "\trtx_insn *insn ATTRIBUTE_UNUSED,\n"
++	       "\tint *pmatch_len_ ATTRIBUTE_UNUSED)%s\n", end);
+       break;
+     }
+-  print_subroutine_start (os, s, &root_pos);
++
++  if (in_header)
++    return;
++
++  print_subroutine_start (f, os, s, &root_pos);
+   if (proc_id == 0)
+     {
+-      printf ("  recog_data.insn = NULL;\n");
++      fprintf (f, "  recog_data.insn = NULL;\n");
+     }
+-  print_state (os, s, 2, true);
+-  printf ("}\n");
++  print_state (f, os, s, 2, true);
++  fprintf (f, "}\n");
+ }
+ 
+ /* Print out a routine of type TYPE that performs ROOT.  */
+ 
+ static void
+-print_subroutine_group (output_state *os, routine_type type, state *root)
++print_subroutine_group (vec<FILE *> &vec, FILE *header, output_state *os,
++			routine_type type, state *root)
+ {
++  FILE *f;
++  unsigned idx;
+   os->type = type;
+   if (use_subroutines_p)
+     {
+@@ -5261,11 +5304,20 @@ print_subroutine_group (output_state *os, routine_type type, state *root)
+       /* Output the subroutines (but not ROOT itself).  */
+       unsigned int i;
+       state *s;
++
++      FILE *f = header;
++      FOR_EACH_VEC_ELT (subroutines, i, s)
++	print_subroutine (header, os, s, i + 1, true);
++
+       FOR_EACH_VEC_ELT (subroutines, i, s)
+-	print_subroutine (os, s, i + 1);
++	{
++	  f = choose_output (vec, idx);
++	  print_subroutine (f, os, s, i + 1);
++	}
+     }
+   /* Output the main routine.  */
+-  print_subroutine (os, root, 0);
++  f = choose_output (vec, idx);
++  print_subroutine (f, os, root, 0);
+ }
+ 
+ /* Return the rtx pattern for the list of rtxes in a define_peephole2.  */
+@@ -5336,6 +5388,29 @@ remove_clobbers (acceptance_type *acceptance_ptr, rtx *pattern_ptr)
+   return true;
+ }
+ 
++auto_vec<FILE *, 10> output_files;
++char header_name[255];
++FILE *header = NULL;
++
++static bool
++handle_arg (const char *arg)
++{
++  printf ("%s\n", arg);
++  if (arg[1] == 'O')
++    {
++      FILE *file = fopen (&arg[2], "w");
++      output_files.safe_push (file);
++      return true;
++    }
++  if (arg[1] == 'H')
++    {
++      snprintf (header_name, 255, "%s", &arg[2]);
++      header = fopen (header_name, "w");
++      return true;
++    }
++  return false;
++}
++
+ int
+ main (int argc, const char **argv)
+ {
+@@ -5343,10 +5418,17 @@ main (int argc, const char **argv)
+ 
+   progname = "genrecog";
+ 
+-  if (!init_rtx_reader_args (argc, argv))
++  if (!init_rtx_reader_args_cb (argc, argv, handle_arg))
+     return (FATAL_EXIT_CODE);
+ 
+-  write_header ();
++  if (output_files.is_empty ())
++    output_files.safe_push (stdout);
++
++  for (auto f : output_files)
++    write_header (f, header_name);
++
++  FILE *file = NULL;
++  unsigned file_idx;
+ 
+   /* Read the machine description.  */
+ 
+@@ -5354,6 +5436,7 @@ main (int argc, const char **argv)
+   while (read_md_rtx (&info))
+     {
+       rtx def = info.def;
++      file = choose_output (output_files, file_idx);
+ 
+       acceptance_type acceptance;
+       acceptance.partial_p = false;
+@@ -5387,8 +5470,8 @@ main (int argc, const char **argv)
+ 
+ 	  /* Declare the gen_split routine that we'll call if the
+ 	     pattern matches.  The definition comes from insn-emit.cc.  */
+-	  printf ("extern rtx_insn *gen_split_%d (rtx_insn *, rtx *);\n",
+-		  info.index);
++	  fprintf (header, "extern rtx_insn *gen_split_%d "
++		   "(rtx_insn *, rtx *);\n", info.index);
+ 	  break;
+ 
+ 	case DEFINE_PEEPHOLE2:
+@@ -5399,8 +5482,8 @@ main (int argc, const char **argv)
+ 
+ 	  /* Declare the gen_peephole2 routine that we'll call if the
+ 	     pattern matches.  The definition comes from insn-emit.cc.  */
+-	  printf ("extern rtx_insn *gen_peephole2_%d (rtx_insn *, rtx *);\n",
+-		  info.index);
++	  fprintf (header, "extern rtx_insn *gen_peephole2_%d "
++		   "(rtx_insn *, rtx *);\n", info.index);
+ 	  break;
+ 
+ 	default:
+@@ -5411,7 +5494,8 @@ main (int argc, const char **argv)
+   if (have_error)
+     return FATAL_EXIT_CODE;
+ 
+-  puts ("\n\n");
++  for (auto f : output_files)
++    fprintf (f, "%s", "\n\n");
+ 
+   /* Optimize each routine in turn.  */
+   optimize_subroutine_group ("recog", &insn_root);
+@@ -5433,15 +5517,27 @@ main (int argc, const char **argv)
+       /* Print out the routines that we just created.  */
+       unsigned int i;
+       pattern_routine *routine;
++
+       FOR_EACH_VEC_ELT (patterns, i, routine)
+-	print_pattern (&os, routine);
++	print_pattern (header, &os, routine, true);
++
++      FOR_EACH_VEC_ELT (patterns, i, routine)
++	{
++	  file = choose_output (output_files, file_idx);
++	  print_pattern (file, &os, routine);
++	}
+     }
+ 
+   /* Print out the matching routines.  */
+-  print_subroutine_group (&os, RECOG, &insn_root);
+-  print_subroutine_group (&os, SPLIT, &split_root);
+-  print_subroutine_group (&os, PEEPHOLE2, &peephole2_root);
++  print_subroutine_group (output_files, header, &os, RECOG, &insn_root);
++  print_subroutine_group (output_files, header, &os, SPLIT, &split_root);
++  print_subroutine_group (output_files, header, &os, PEEPHOLE2, &peephole2_root);
++
++  fclose (header);
+ 
+-  fflush (stdout);
+-  return (ferror (stdout) != 0 ? FATAL_EXIT_CODE : SUCCESS_EXIT_CODE);
++  int ret = SUCCESS_EXIT_CODE;
++  for (FILE *f : output_files)
++    if (fclose (f) != 0)
++      ret = FATAL_EXIT_CODE;
++  return ret;
+ }
+diff --git a/gcc/gentarget-def.cc b/gcc/gentarget-def.cc
+index 061b1e7247c1..3a462560cc1b 100644
+--- a/gcc/gentarget-def.cc
++++ b/gcc/gentarget-def.cc
+@@ -191,7 +191,7 @@ def_target_insn (const char *name, const char *prototype)
+ 	      printf ("target_have_%s (void)\n", name);
+ 	      printf ("{\n");
+ 	      printf ("  return ");
+-	      rtx_reader_ptr->print_c_condition (test);
++	      rtx_reader_ptr->print_c_condition (stdout, test);
+ 	      printf (";\n");
+ 	      printf ("}\n");
+ 	    }
+diff --git a/gcc/read-md.cc b/gcc/read-md.cc
+index 93d1ea437812..aeb1cced00d0 100644
+--- a/gcc/read-md.cc
++++ b/gcc/read-md.cc
+@@ -192,9 +192,9 @@ md_reader::fprint_c_condition (FILE *outf, const char *cond)
+ /* Special fprint_c_condition for writing to STDOUT.  */
+ 
+ void
+-md_reader::print_c_condition (const char *cond)
++md_reader::print_c_condition (FILE *outf, const char *cond)
+ {
+-  fprint_c_condition (stdout, cond);
++  fprint_c_condition (outf, cond);
+ }
+ 
+ /* A vfprintf-like function for reporting an error against line LINENO
+diff --git a/gcc/read-md.h b/gcc/read-md.h
+index e613c42b7241..b42add391ed8 100644
+--- a/gcc/read-md.h
++++ b/gcc/read-md.h
+@@ -205,7 +205,7 @@ class md_reader
+ 
+   const char *join_c_conditions (const char *cond1, const char *cond2);
+   void fprint_c_condition (FILE *outf, const char *cond);
+-  void print_c_condition (const char *cond);
++  void print_c_condition (FILE *outf, const char *cond);
+ 
+   /* Defined in read-rtl.cc.  */
+   const char *apply_iterator_to_string (const char *string);
+
+base-commit: a22dfe208d94105a6e587a3b25e8fe8d62444d8a
+-- 
+2.47.1
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-30 11:04 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-30 11:04 UTC (permalink / raw
  To: gentoo-commits
commit:     b2540825f96c83e449d9ffe74894a0cc173ae47e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 30 11:01:26 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Nov 30 11:03:22 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b2540825
15.0.0: don't pass -fcf-protection for offload
Well, actually, disable it.
Bug: https://bugs.gentoo.org/945296
Bug: https://gcc.gnu.org/PR114717
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/26_all_enable-cet.patch | 2 +-
 15.0.0/gentoo/README.history          | 1 +
 2 files changed, 2 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/26_all_enable-cet.patch b/15.0.0/gentoo/26_all_enable-cet.patch
index 85591e9..be772d0 100644
--- a/15.0.0/gentoo/26_all_enable-cet.patch
+++ b/15.0.0/gentoo/26_all_enable-cet.patch
@@ -68,7 +68,7 @@ Only supported on amd64.
 +   We use a new option (EXTRA_OPTIONS_CF) here to avoid turning
 +   this on accidentally for other arches. */
 +#ifdef EXTRA_OPTIONS_CF
-+#define DEFAULT_FLAG_CF_SPEC " %{!m16:%{!m32:%{!fcf-protection*:%{!fno-cf-protection:-fcf-protection}}}}"
++#define DEFAULT_FLAG_CF_SPEC " %{!m16:%{!m32:%{!fcf-protection*:%{!fno-cf-protection:-fcf-protection}}}} -foffload-options=-fcf-protection=none"
 +#endif
 +#ifndef DEFAULT_FLAG_CF_SPEC
 +#define DEFAULT_FLAG_CF_SPEC ""
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 926d4de..f2fbcd7 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 ??
 
 	- 72_all_PR111600-genemit-Distribute-evenly-to-files.patch
+	U 26_all_enable-cet.patch
 
 28	25 November 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-11-30 11:30 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-11-30 11:30 UTC (permalink / raw
  To: gentoo-commits
commit:     d066fc8f8de408b4e8d9d12a93f19d60ec08e250
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 30 11:29:18 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Nov 30 11:29:58 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=d066fc8f
15.0.0: pass -fno-stack-protector for offloading
--enable-default-ssp doesn't seem to cover this.
Bug: https://bugs.gentoo.org/945296
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/04_all_nossp-on-nostdlib.patch | 2 +-
 15.0.0/gentoo/README.history                 | 1 +
 2 files changed, 2 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/04_all_nossp-on-nostdlib.patch b/15.0.0/gentoo/04_all_nossp-on-nostdlib.patch
index e17b6a3..4462c0e 100644
--- a/15.0.0/gentoo/04_all_nossp-on-nostdlib.patch
+++ b/15.0.0/gentoo/04_all_nossp-on-nostdlib.patch
@@ -8,7 +8,7 @@ https://bugs.gentoo.org/484714
  #endif
  
 +#ifdef ENABLE_DEFAULT_SSP
-+#define NO_SSP_SPEC "%{nostdlib|nodefaultlibs|ffreestanding:-fno-stack-protector} "
++#define NO_SSP_SPEC "%{nostdlib|nodefaultlibs|ffreestanding:-fno-stack-protector} -foffload-options=-fno-stack-protector "
 +#else
 +#define NO_SSP_SPEC ""
 +#endif
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index f2fbcd7..fc9e803 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 ??
 
 	- 72_all_PR111600-genemit-Distribute-evenly-to-files.patch
+	U 04_all_nossp-on-nostdlib.patch
 	U 26_all_enable-cet.patch
 
 28	25 November 2024
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-01 22:51 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-01 22:51 UTC (permalink / raw
  To: gentoo-commits
commit:     ff1de10818c52725954f2f02e718c05c231512e4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Dec  1 22:49:19 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec  1 22:49:34 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ff1de108
15.0.0: rebase 28_all_drop_CFLAGS_sed.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/28_all_drop_CFLAGS_sed.patch | 12 ++++++------
 15.0.0/gentoo/README.history               |  1 +
 2 files changed, 7 insertions(+), 6 deletions(-)
diff --git a/15.0.0/gentoo/28_all_drop_CFLAGS_sed.patch b/15.0.0/gentoo/28_all_drop_CFLAGS_sed.patch
index 764f34c..fb514cb 100644
--- a/15.0.0/gentoo/28_all_drop_CFLAGS_sed.patch
+++ b/15.0.0/gentoo/28_all_drop_CFLAGS_sed.patch
@@ -3,7 +3,7 @@ https://github.com/InBetweenNames/gentooLTO/issues/846
 https://github.com/vaeth/portage-bashrc-mv/issues/11
 --- a/gcc/configure
 +++ b/gcc/configure
-@@ -5388,13 +5388,6 @@ ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ex
+@@ -5473,13 +5473,6 @@ ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ex
  ac_compiler_gnu=$ac_cv_cxx_compiler_gnu
  
  
@@ -11,15 +11,15 @@ https://github.com/vaeth/portage-bashrc-mv/issues/11
 -# optimizations to be activated explicitly by the toplevel.
 -case "$CC" in
 -  */prev-gcc/xgcc*) ;;
--  *) CFLAGS=`echo "$CFLAGS " | sed -e "s/-Ofast[ 	]//" -e "s/-O[gs][ 	]//" -e "s/-O[0-9]*[ 	]//" `
--     CXXFLAGS=`echo "$CXXFLAGS " | sed -e "s/-Ofast[ 	]//" -e "s/-O[gs][ 	]//" -e "s/-O[0-9]*[ 	]//" ` ;;
+-  *) CFLAGS=`echo "$CFLAGS " | sed -e "s/-Ofast[ 	]//" -e "s/-O[gs][ 	]//" -e "s/[^,]-O[0-9]*[ 	]//" `
+-     CXXFLAGS=`echo "$CXXFLAGS " | sed -e "s/-Ofast[ 	]//" -e "s/-O[gs][ 	]//" -e "s/[^,]-O[0-9]*[ 	]//" ` ;;
 -esac
  
  
  
 --- a/gcc/configure.ac
 +++ b/gcc/configure.ac
-@@ -440,13 +440,6 @@ ACX_PROG_GDC([-I"$srcdir"/d])
+@@ -463,13 +463,6 @@ ACX_PROG_GDC([-I"$srcdir"/d])
  # Do configure tests with the C++ compiler, since that's what we build with.
  AC_LANG(C++)
  
@@ -27,8 +27,8 @@ https://github.com/vaeth/portage-bashrc-mv/issues/11
 -# optimizations to be activated explicitly by the toplevel.
 -case "$CC" in
 -  */prev-gcc/xgcc*) ;;
--  *) CFLAGS=`echo "$CFLAGS " | sed -e "s/-Ofast[[ 	]]//" -e "s/-O[[gs]][[ 	]]//" -e "s/-O[[0-9]]*[[ 	]]//" `
--     CXXFLAGS=`echo "$CXXFLAGS " | sed -e "s/-Ofast[[ 	]]//" -e "s/-O[[gs]][[ 	]]//" -e "s/-O[[0-9]]*[[ 	]]//" ` ;;
+-  *) CFLAGS=`echo "$CFLAGS " | sed -e "s/-Ofast[[ 	]]//" -e "s/-O[[gs]][[ 	]]//" -e "s/[[^,]]-O[[0-9]]*[[ 	]]//" `
+-     CXXFLAGS=`echo "$CXXFLAGS " | sed -e "s/-Ofast[[ 	]]//" -e "s/-O[[gs]][[ 	]]//" -e "s/[[^,]]-O[[0-9]]*[[ 	]]//" ` ;;
 -esac
  AC_SUBST(CFLAGS)
  AC_SUBST(CXXFLAGS)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index fc9e803..2b369b3 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -3,6 +3,7 @@
 	- 72_all_PR111600-genemit-Distribute-evenly-to-files.patch
 	U 04_all_nossp-on-nostdlib.patch
 	U 26_all_enable-cet.patch
+	U 28_all_drop_CFLAGS_sed.patch
 
 28	25 November 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-01 22:51 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-01 22:51 UTC (permalink / raw
  To: gentoo-commits
commit:     327cf5e12642fc4d22c9a65971c11a4c6d22aebf
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Dec  1 22:44:01 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec  1 22:49:34 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=327cf5e1
15.0.0: cut patchset 29
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 2b369b3..5fb36c9 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-??
+29	1 December 2024
 
 	- 72_all_PR111600-genemit-Distribute-evenly-to-files.patch
 	U 04_all_nossp-on-nostdlib.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-04 20:40 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-04 20:40 UTC (permalink / raw
  To: gentoo-commits
commit:     2c9ed0ca7f95939d71b6db53760b85a72847d173
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Dec  4 20:40:19 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Dec  4 20:40:19 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=2c9ed0ca
15.0.0: rebase 28_all_drop_CFLAGS_sed.patch
It might be this can be dropped now but it's still so brittle.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/28_all_drop_CFLAGS_sed.patch | 48 +++++++++++++++++++++++++-----
 1 file changed, 40 insertions(+), 8 deletions(-)
diff --git a/15.0.0/gentoo/28_all_drop_CFLAGS_sed.patch b/15.0.0/gentoo/28_all_drop_CFLAGS_sed.patch
index fb514cb..b160c92 100644
--- a/15.0.0/gentoo/28_all_drop_CFLAGS_sed.patch
+++ b/15.0.0/gentoo/28_all_drop_CFLAGS_sed.patch
@@ -3,32 +3,64 @@ https://github.com/InBetweenNames/gentooLTO/issues/846
 https://github.com/vaeth/portage-bashrc-mv/issues/11
 --- a/gcc/configure
 +++ b/gcc/configure
-@@ -5473,13 +5473,6 @@ ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ex
+@@ -5473,29 +5473,6 @@ ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ex
  ac_compiler_gnu=$ac_cv_cxx_compiler_gnu
  
  
--# Remove the -O2: for historical reasons, unless bootstrapping we prefer
+-# Remove all -O flags: for historical reasons, unless bootstrapping we prefer
 -# optimizations to be activated explicitly by the toplevel.
 -case "$CC" in
 -  */prev-gcc/xgcc*) ;;
--  *) CFLAGS=`echo "$CFLAGS " | sed -e "s/-Ofast[ 	]//" -e "s/-O[gs][ 	]//" -e "s/[^,]-O[0-9]*[ 	]//" `
--     CXXFLAGS=`echo "$CXXFLAGS " | sed -e "s/-Ofast[ 	]//" -e "s/-O[gs][ 	]//" -e "s/[^,]-O[0-9]*[ 	]//" ` ;;
+-  *)
+-    new_CFLAGS=
+-    for flag in $CFLAGS; do
+-      case $flag in
+-	-O*) ;;
+-	*) new_CFLAGS="$new_CFLAGS $flag" ;;
+-      esac
+-    done
+-    CFLAGS=$new_CFLAGS
+-    new_CXXFLAGS=
+-    for flag in $CXXFLAGS; do
+-      case $flag in
+-	-O*) ;;
+-	*) new_CXXFLAGS="$new_CXXFLAGS $flag" ;;
+-      esac
+-    done
+-    CXXFLAGS=$new_CXXFLAGS
+-    ;;
 -esac
  
  
  
 --- a/gcc/configure.ac
 +++ b/gcc/configure.ac
-@@ -463,13 +463,6 @@ ACX_PROG_GDC([-I"$srcdir"/d])
+@@ -463,29 +463,6 @@ ACX_PROG_GDC([-I"$srcdir"/d])
  # Do configure tests with the C++ compiler, since that's what we build with.
  AC_LANG(C++)
  
--# Remove the -O2: for historical reasons, unless bootstrapping we prefer
+-# Remove all -O flags: for historical reasons, unless bootstrapping we prefer
 -# optimizations to be activated explicitly by the toplevel.
 -case "$CC" in
 -  */prev-gcc/xgcc*) ;;
--  *) CFLAGS=`echo "$CFLAGS " | sed -e "s/-Ofast[[ 	]]//" -e "s/-O[[gs]][[ 	]]//" -e "s/[[^,]]-O[[0-9]]*[[ 	]]//" `
--     CXXFLAGS=`echo "$CXXFLAGS " | sed -e "s/-Ofast[[ 	]]//" -e "s/-O[[gs]][[ 	]]//" -e "s/[[^,]]-O[[0-9]]*[[ 	]]//" ` ;;
+-  *)
+-    new_CFLAGS=
+-    for flag in $CFLAGS; do
+-      case $flag in
+-	-O*) ;;
+-	*) new_CFLAGS="$new_CFLAGS $flag" ;;
+-      esac
+-    done
+-    CFLAGS=$new_CFLAGS
+-    new_CXXFLAGS=
+-    for flag in $CXXFLAGS; do
+-      case $flag in
+-	-O*) ;;
+-	*) new_CXXFLAGS="$new_CXXFLAGS $flag" ;;
+-      esac
+-    done
+-    CXXFLAGS=$new_CXXFLAGS
+-    ;;
 -esac
  AC_SUBST(CFLAGS)
  AC_SUBST(CXXFLAGS)
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-06 17:33 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-06 17:33 UTC (permalink / raw
  To: gentoo-commits
commit:     a702fbd08bae90ab51599a2bff41db041f43e881
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Dec  6 17:33:27 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Dec  6 17:33:27 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=a702fbd0
15.0.0: add 73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch
Not yet merged upstream but improves diagnostics and it was done partly
for us, so let's test it out.
Bug: https://gcc.gnu.org/PR117629
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-c-special-case-some-bool-errors-with-C23.patch | 312 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   4 +
 2 files changed, 316 insertions(+)
diff --git a/15.0.0/gentoo/73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch b/15.0.0/gentoo/73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch
new file mode 100644
index 0000000..3c3696e
--- /dev/null
+++ b/15.0.0/gentoo/73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch
@@ -0,0 +1,312 @@
+https://inbox.sourceware.org/gcc-patches/20241126034902.1294094-1-dmalcolm@redhat.com/
+
+From 3d35e4348a0771cedc5a540f70eaa90f3ea68f23 Mon Sep 17 00:00:00 2001
+Message-ID: <3d35e4348a0771cedc5a540f70eaa90f3ea68f23.1733506366.git.sam@gentoo.org>
+From: David Malcolm <dmalcolm@redhat.com>
+Date: Mon, 25 Nov 2024 22:49:02 -0500
+Subject: [PATCH] c: special-case some "bool" errors with C23 [PR117629]
+
+This patch attempts to provide better error messages for
+code compiled with C23 that hasn't been updated for
+"bool", "true", and "false" becoming keywords (based on
+a brief review of the Gentoo bug tracker links given at
+https://gcc.gnu.org/pipermail/gcc/2024-November/245185.html).
+
+Specifically:
+
+(1) with "typedef int bool;" previously we emitted:
+
+t1.c:7:13: error: two or more data types in declaration specifiers
+    7 | typedef int bool;
+      |             ^~~~
+t1.c:7:1: warning: useless type name in empty declaration
+    7 | typedef int bool;
+      | ^~~~~~~
+
+whereas with this patch we emit:
+
+t1.c:7:13: error: 'bool' cannot be defined via 'typedef'
+    7 | typedef int bool;
+      |             ^~~~
+t1.c:7:13: note: 'bool' is a keyword with '-std=c23' onwards
+t1.c:7:1: warning: useless type name in empty declaration
+    7 | typedef int bool;
+      | ^~~~~~~
+
+(2) with "int bool;" previously we emitted:
+
+t2.c:7:5: error: two or more data types in declaration specifiers
+    7 | int bool;
+      |     ^~~~
+t2.c:7:1: warning: useless type name in empty declaration
+    7 | int bool;
+      | ^~~
+
+whereas with this patch we emit:
+
+t2.c:7:5: error: 'bool' cannot be used here
+    7 | int bool;
+      |     ^~~~
+t2.c:7:5: note: 'bool' is a keyword with '-std=c23' onwards
+t2.c:7:1: warning: useless type name in empty declaration
+    7 | int bool;
+      | ^~~
+
+(3) with "typedef enum { false = 0, true = 1 } _Bool;" previously we
+emitted:
+
+t3.c:7:16: error: expected identifier before 'false'
+    7 | typedef enum { false = 0, true = 1 } _Bool;
+      |                ^~~~~
+t3.c:7:38: error: expected ';', identifier or '(' before '_Bool'
+    7 | typedef enum { false = 0, true = 1 } _Bool;
+      |                                      ^~~~~
+t3.c:7:38: warning: useless type name in empty declaration
+
+whereas with this patch we emit:
+
+t3.c:7:16: error: cannot use keyword 'false' as enumeration constant
+    7 | typedef enum { false = 0, true = 1 } _Bool;
+      |                ^~~~~
+t3.c:7:16: note: 'false' is a keyword with '-std=c23' onwards
+t3.c:7:38: error: expected ';', identifier or '(' before '_Bool'
+    7 | typedef enum { false = 0, true = 1 } _Bool;
+      |                                      ^~~~~
+t3.c:7:38: warning: useless type name in empty declaration
+
+Successfully bootstrapped & regrtested on x86_64-pc-linux-gnu.
+OK for trunk?
+
+gcc/c/ChangeLog:
+	PR c/117629
+	* c-decl.cc (declspecs_add_type): Special-case attempts to use
+	bool as a typedef name or declaration name.
+	* c-errors.cc (add_note_about_new_keyword): New.
+	* c-parser.cc (report_bad_enum_name): New, split out from...
+	(c_parser_enum_specifier): ...here, adding handling for RID_FALSE
+	and RID_TRUE.
+	* c-tree.h (add_note_about_new_keyword): New decl.
+
+gcc/testsuite/ChangeLog:
+	PR c/117629
+	* gcc.dg/auto-type-2.c: Update expected output with _Bool.
+	* gcc.dg/c23-bool-errors-1.c: New test.
+	* gcc.dg/c23-bool-errors-2.c: New test.
+	* gcc.dg/c23-bool-errors-3.c: New test.
+
+Signed-off-by: David Malcolm <dmalcolm@redhat.com>
+---
+ gcc/c/c-decl.cc                          | 18 +++++++-
+ gcc/c/c-errors.cc                        | 13 ++++++
+ gcc/c/c-parser.cc                        | 53 +++++++++++++++++++-----
+ gcc/c/c-tree.h                           |  3 ++
+ gcc/testsuite/gcc.dg/auto-type-2.c       |  2 +-
+ gcc/testsuite/gcc.dg/c23-bool-errors-1.c |  9 ++++
+ gcc/testsuite/gcc.dg/c23-bool-errors-2.c |  9 ++++
+ gcc/testsuite/gcc.dg/c23-bool-errors-3.c | 15 +++++++
+ 8 files changed, 109 insertions(+), 13 deletions(-)
+ create mode 100644 gcc/testsuite/gcc.dg/c23-bool-errors-1.c
+ create mode 100644 gcc/testsuite/gcc.dg/c23-bool-errors-2.c
+ create mode 100644 gcc/testsuite/gcc.dg/c23-bool-errors-3.c
+
+diff --git a/gcc/c/c-decl.cc b/gcc/c/c-decl.cc
+index 7abf1921b577..91d5fee50402 100644
+--- a/gcc/c/c-decl.cc
++++ b/gcc/c/c-decl.cc
+@@ -12493,8 +12493,22 @@ declspecs_add_type (location_t loc, struct c_declspecs *specs,
+ 	     "__auto_type".  */
+ 	  if (specs->typespec_word != cts_none)
+ 	    {
+-	      error_at (loc,
+-			"two or more data types in declaration specifiers");
++	      if (i == RID_BOOL)
++		{
++		  auto_diagnostic_group d;
++		  if (specs->storage_class == csc_typedef)
++		    error_at (loc,
++			      "%qs cannot be defined via %<typedef%>",
++			      IDENTIFIER_POINTER (type));
++		  else
++		    error_at (loc,
++			      "%qs cannot be used here",
++			      IDENTIFIER_POINTER (type));
++		  add_note_about_new_keyword (loc, type, "-std=c23");
++		}
++	      else
++		error_at (loc,
++			  "two or more data types in declaration specifiers");
+ 	      return specs;
+ 	    }
+ 	  switch (i)
+diff --git a/gcc/c/c-errors.cc b/gcc/c/c-errors.cc
+index 77f008eba1c2..cc9bb128ee8b 100644
+--- a/gcc/c/c-errors.cc
++++ b/gcc/c/c-errors.cc
+@@ -215,3 +215,16 @@ out:
+   va_end (ap);
+   return warned;
+ }
++
++/* Issue a note to the user at LOC that KEYWORD_ID is a keyword
++   in STD_OPTION version of the standard onwards.  */
++
++void
++add_note_about_new_keyword (location_t loc,
++			    tree keyword_id,
++			    const char *std_option)
++{
++  gcc_assert (TREE_CODE (keyword_id) == IDENTIFIER_NODE);
++  inform (loc, "%qs is a keyword with %qs onwards",
++	  IDENTIFIER_POINTER (keyword_id), std_option);
++}
+diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
+index 4ec0ee85ac49..18ba82e83f02 100644
+--- a/gcc/c/c-parser.cc
++++ b/gcc/c/c-parser.cc
+@@ -3785,6 +3785,48 @@ c_parser_declspecs (c_parser *parser, struct c_declspecs *specs,
+     specs->postfix_attrs = c_parser_std_attribute_specifier_sequence (parser);
+ }
+ 
++/* Complain about a non-CPP_NAME within an enumerator list.  */
++
++static void
++report_bad_enum_name (c_parser *parser)
++{
++  if (!parser->error)
++    {
++      c_token *token = c_parser_peek_token (parser);
++      switch (token->type)
++	{
++	default:
++	  break;
++	case CPP_CLOSE_BRACE:
++	  /* Give a nicer error for "enum {}".  */
++	  error_at (token->location,
++		    "empty enum is invalid");
++	  parser->error = true;
++	  return;
++	case CPP_KEYWORD:
++	  /* Give a nicer error for attempts to use "true" and "false"
++	     in enums with C23 onwards.  */
++	  if (token->keyword == RID_FALSE
++	      || token->keyword == RID_TRUE)
++	    {
++	      auto_diagnostic_group d;
++	      error_at (token->location,
++			"cannot use keyword %qs as enumeration constant",
++			IDENTIFIER_POINTER (token->value));
++	      add_note_about_new_keyword (token->location,
++					  token->value,
++					  "-std=c23");
++	      parser->error = true;
++	      return;
++	    }
++	  break;
++	}
++    }
++
++  /* Otherwise, a more generic error message.  */
++  c_parser_error (parser, "expected identifier");
++}
++
+ /* Parse an enum specifier (C90 6.5.2.2, C99 6.7.2.2, C11 6.7.2.2).
+ 
+    enum-specifier:
+@@ -3952,16 +3994,7 @@ c_parser_enum_specifier (c_parser *parser)
+ 	  location_t decl_loc, value_loc;
+ 	  if (c_parser_next_token_is_not (parser, CPP_NAME))
+ 	    {
+-	      /* Give a nicer error for "enum {}".  */
+-	      if (c_parser_next_token_is (parser, CPP_CLOSE_BRACE)
+-		  && !parser->error)
+-		{
+-		  error_at (c_parser_peek_token (parser)->location,
+-			    "empty enum is invalid");
+-		  parser->error = true;
+-		}
+-	      else
+-		c_parser_error (parser, "expected identifier");
++	      report_bad_enum_name (parser);
+ 	      c_parser_skip_until_found (parser, CPP_CLOSE_BRACE, NULL);
+ 	      values = error_mark_node;
+ 	      break;
+diff --git a/gcc/c/c-tree.h b/gcc/c/c-tree.h
+index d39bd238103e..e98bd4f2fd8d 100644
+--- a/gcc/c/c-tree.h
++++ b/gcc/c/c-tree.h
+@@ -955,6 +955,9 @@ extern bool pedwarn_c11 (location_t, diagnostic_option_id, const char *, ...)
+     ATTRIBUTE_GCC_DIAG(3,4);
+ extern bool pedwarn_c23 (location_t, diagnostic_option_id, const char *, ...)
+     ATTRIBUTE_GCC_DIAG(3,4);
++extern void add_note_about_new_keyword (location_t loc,
++					tree keyword_id,
++					const char *std_option);
+ 
+ extern void
+ set_c_expr_source_range (c_expr *expr,
+diff --git a/gcc/testsuite/gcc.dg/auto-type-2.c b/gcc/testsuite/gcc.dg/auto-type-2.c
+index 761671b3c5a4..f484acb4c916 100644
+--- a/gcc/testsuite/gcc.dg/auto-type-2.c
++++ b/gcc/testsuite/gcc.dg/auto-type-2.c
+@@ -20,4 +20,4 @@ signed __auto_type e7 = 0; /* { dg-error "__auto_type" } */
+ unsigned __auto_type e8 = 0; /* { dg-error "__auto_type" } */
+ _Complex __auto_type e9 = 0; /* { dg-error "__auto_type" } */
+ int __auto_type e10 = 0; /* { dg-error "two or more data types" } */
+-__auto_type _Bool e11 = 0; /* { dg-error "two or more data types" } */
++__auto_type _Bool e11 = 0; /* { dg-error "'_Bool' cannot be used here" } */
+diff --git a/gcc/testsuite/gcc.dg/c23-bool-errors-1.c b/gcc/testsuite/gcc.dg/c23-bool-errors-1.c
+new file mode 100644
+index 000000000000..8a33d36a8891
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/c23-bool-errors-1.c
+@@ -0,0 +1,9 @@
++/* Test error-handling for legacy code that tries to
++   define "bool" with C23.  */
++
++/* { dg-do compile } */
++/* { dg-options "-std=c23" } */
++
++typedef int bool; /* { dg-error "'bool' cannot be defined via 'typedef'" } */
++/* { dg-message "'bool' is a keyword with '-std=c23' onwards" "" { target *-*-* } .-1 } */
++/* { dg-warning "useless type name in empty declaration"  "" { target *-*-* } .-2 } */
+diff --git a/gcc/testsuite/gcc.dg/c23-bool-errors-2.c b/gcc/testsuite/gcc.dg/c23-bool-errors-2.c
+new file mode 100644
+index 000000000000..1a66e3aea67e
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/c23-bool-errors-2.c
+@@ -0,0 +1,9 @@
++/* Test error-handling for legacy code that tries to
++   use a variable named "bool" with C23.  */
++
++/* { dg-do compile } */
++/* { dg-options "-std=c23" } */
++
++int bool; /* { dg-error "'bool' cannot be used here" } */
++/* { dg-message "'bool' is a keyword with '-std=c23' onwards" "" { target *-*-* } .-1 } */
++/* { dg-warning "useless type name in empty declaration" "" { target *-*-* } .-2 } */
+diff --git a/gcc/testsuite/gcc.dg/c23-bool-errors-3.c b/gcc/testsuite/gcc.dg/c23-bool-errors-3.c
+new file mode 100644
+index 000000000000..634c8ac45a52
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/c23-bool-errors-3.c
+@@ -0,0 +1,15 @@
++/* Test error-handling for legacy code that tries to
++   define "false" or "true" within enums with C23.  */
++
++/* { dg-do compile } */
++/* { dg-options "-std=c23" } */
++
++typedef enum { false = 0, true = 1 } _Bool; /* { dg-error "cannot use keyword 'false' as enumeration constant" }
++/* { dg-message "'false' is a keyword with '-std=c23' onwards" "" { target *-*-* } .-1 } */
++/* { dg-error "38: expected ';', identifier or '\\\(' before '_Bool'" "" { target *-*-* } .-2 } */
++/* { dg-warning "38: useless type name in empty declaration" "" { target *-*-* } .-3 } */
++
++typedef enum { true = 1, false = 0 } _Bool; /* { dg-error "cannot use keyword 'true' as enumeration constant" }
++/* { dg-message "'true' is a keyword with '-std=c23' onwards" "" { target *-*-* } .-1 } */
++/* { dg-error "38: expected ';', identifier or '\\\(' before '_Bool'" "" { target *-*-* } .-2 } */
++/* { dg-warning "38: useless type name in empty declaration" "" { target *-*-* } .-3 } */
+
+base-commit: 115e4bf54ec91a4f358a9e68dcd7a234b0ccc5b8
+-- 
+2.47.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 5fb36c9..aef08ee 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+30	??
+
+	+ 73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch
+
 29	1 December 2024
 
 	- 72_all_PR111600-genemit-Distribute-evenly-to-files.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-08 22:41 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-08 22:41 UTC (permalink / raw
  To: gentoo-commits
commit:     b89362d1145e9068917132227255434586193837
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Dec  8 22:41:08 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec  8 22:41:08 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b89362d1
15.0.0: cut patchset 30
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index aef08ee..b42dfc7 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-30	??
+30	8 December 2024
 
 	+ 73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-09  3:05 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-09  3:05 UTC (permalink / raw
  To: gentoo-commits
commit:     c52e67271ce71be301691e491fd45d01b779e8fb
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Dec  9 03:04:45 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Dec  9 03:04:45 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=c52e6727
15.0.0: add patches for C FAM ICEs w/ C23
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...mpatibility-for-types-with-flexible-array.patch | 330 +++++++++++++++++++++
 ...724-testsuite-fix-LTO-flags-in-pr112716.c.patch |  27 ++
 15.0.0/gentoo/README.history                       |   5 +
 3 files changed, 362 insertions(+)
diff --git a/15.0.0/gentoo/74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch b/15.0.0/gentoo/74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
new file mode 100644
index 0000000..3c20493
--- /dev/null
+++ b/15.0.0/gentoo/74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
@@ -0,0 +1,330 @@
+From e1d3dfa0936ca5b50c87f6ddf5347fa401a703f6 Mon Sep 17 00:00:00 2001
+Message-ID: <e1d3dfa0936ca5b50c87f6ddf5347fa401a703f6.1733713329.git.sam@gentoo.org>
+From: Martin Uecker <uecker@tugraz.at>
+Date: Mon, 9 Dec 2024 00:11:58 +0100
+Subject: [PATCH 1/2] Fix type compatibility for types with flexible array
+ member [PR113688,PR114014,PR117724]
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+Hi Richard,
+
+this is another version.  It now adds an "ignore_size" flag
+to gimple_canonical_types_compatible_p and uses this instead
+of having the complicated special case for arrays at the
+end.  Also zero-sized members are now ignored again, except
+if they are arrays at the end where then only the size is
+ignored.  This can still be stricter than before for the 
+case where there are zero-sized arrays at the end (e.g.
+before element type could differ).
+
+Martin
+
+Bootstrapped and regression tested on x86_64.
+
+Fix type compatibility for types with flexible array member [PR113688,PR114014,PR117724]
+
+    verify_type checks the compatibility of TYPE_CANONICAL using
+    gimple_canonical_types_compatible_p.   But it is stricter than what the
+    C standard requires and therefor inconsistent with how TYPE_CANONICAL is set
+    in the C FE.  Here, the logic is changed to ignore the array size when it
+    is the last element of a structure or union.  To not get errors because of
+    an inconsistent number of members, zero-sized arrays which are the last
+    element are not ignored anymore when checking the fields of a struct (which
+    in this particular case is stricter than what was done before).  Finally,
+    exceptions are added that allow the TYPE_MODE of a type with an array as
+    last member and of such arrays to differ from another compatible type.
+
+            PR c/112716
+            PR c/113688
+            PR c/114014
+            PR c/117724
+
+    gcc/ChangeLog:
+            * tree.cc (gimple_canonical_types_compatible_p): Add
+              `ignore_size' parameter and revise logic.
+            (verify_type): Add exceptions.
+
+    gcc/lto/ChangeLog:
+            * lto-common.cc (hash_canonical_type): Add exceptions.
+
+    gcc/testsuite/ChangeLog:
+            * gcc.dg/pr112716.c: New test.
+            * gcc.dg/pr113688.c: New test.
+            * gcc.dg/pr114014.c: New test.
+            * gcc.dg/pr117724.c: New test.
+---
+ gcc/lto/lto-common.cc           |  9 ++++--
+ gcc/testsuite/gcc.dg/pr112716.c | 40 +++++++++++++++++++++++++
+ gcc/testsuite/gcc.dg/pr113688.c |  8 +++++
+ gcc/testsuite/gcc.dg/pr114014.c | 14 +++++++++
+ gcc/testsuite/gcc.dg/pr117724.c | 16 ++++++++++
+ gcc/tree.cc                     | 53 +++++++++++++++++++++++++--------
+ gcc/tree.h                      |  3 +-
+ 7 files changed, 127 insertions(+), 16 deletions(-)
+ create mode 100644 gcc/testsuite/gcc.dg/pr112716.c
+ create mode 100644 gcc/testsuite/gcc.dg/pr113688.c
+ create mode 100644 gcc/testsuite/gcc.dg/pr114014.c
+ create mode 100644 gcc/testsuite/gcc.dg/pr117724.c
+
+diff --git a/gcc/lto/lto-common.cc b/gcc/lto/lto-common.cc
+index 86a309f92b40..f65a9d1c7b6f 100644
+--- a/gcc/lto/lto-common.cc
++++ b/gcc/lto/lto-common.cc
+@@ -254,7 +254,8 @@ hash_canonical_type (tree type)
+      checked.  */
+   code = tree_code_for_canonical_type_merging (TREE_CODE (type));
+   hstate.add_int (code);
+-  hstate.add_int (TYPE_MODE (type));
++  if (!RECORD_OR_UNION_TYPE_P (type))
++    hstate.add_int (TYPE_MODE (type));
+ 
+   /* Incorporate common features of numerical types.  */
+   if (INTEGRAL_TYPE_P (type)
+@@ -332,7 +333,11 @@ hash_canonical_type (tree type)
+ 	    && (! DECL_SIZE (f)
+ 		|| ! integer_zerop (DECL_SIZE (f))))
+ 	  {
+-	    iterative_hash_canonical_type (TREE_TYPE (f), hstate);
++	    tree t = TREE_TYPE (f);
++	    if (!TREE_CHAIN (f)
++		&& TREE_CODE (t) == ARRAY_TYPE)
++	      t = TREE_TYPE  (t);
++	    iterative_hash_canonical_type (t, hstate);
+ 	    nf++;
+ 	  }
+ 
+diff --git a/gcc/testsuite/gcc.dg/pr112716.c b/gcc/testsuite/gcc.dg/pr112716.c
+new file mode 100644
+index 000000000000..109dd252f0d6
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/pr112716.c
+@@ -0,0 +1,40 @@
++/* { dg-do compile } */
++/* { dg-options "-lfto -O2" } */
++
++#define T1 int[n]
++#define T2 int[n]
++
++// TU 1
++void bar(void*);
++
++[[gnu::noinline,gnu::noipa]]
++int foo(void *p, void *q)
++{
++	int n = 5;
++	struct foo { int x; typeof(T1) y; } *p2 = p;
++	p2->x = 1;
++	bar(q);
++	return p2->x;
++}
++
++int main()
++{
++	int n = 5;
++	void *p = __builtin_malloc(sizeof(struct foo { int x; typeof(T1) y; }));
++
++	if (!p)
++		return 0;
++
++	if (2 != foo(p, p))
++		__builtin_abort();
++
++	return 0;
++}
++// TU 2
++void bar(void* q)
++{
++	int n = 5;
++	struct foo { int x; typeof(T2) y; } *q2 = q;
++	q2->x = 2;
++}
++
+diff --git a/gcc/testsuite/gcc.dg/pr113688.c b/gcc/testsuite/gcc.dg/pr113688.c
+new file mode 100644
+index 000000000000..8dee8c86f1bf
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/pr113688.c
+@@ -0,0 +1,8 @@
++/* { dg-do compile } */
++/* { dg-options "-g" } */
++
++struct S{int x,y[1];}*a;
++int main(void){
++	struct S{int x,y[];};
++}
++
+diff --git a/gcc/testsuite/gcc.dg/pr114014.c b/gcc/testsuite/gcc.dg/pr114014.c
+new file mode 100644
+index 000000000000..1531ffab1b75
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/pr114014.c
+@@ -0,0 +1,14 @@
++/* PR c/114014
++ * { dg-do compile }
++ * { dg-options "-std=gnu23 -g" } */
++
++struct r {
++  int a;
++  char b[];
++};
++struct r {
++  int a;
++  char b[0];
++};
++
++
+diff --git a/gcc/testsuite/gcc.dg/pr117724.c b/gcc/testsuite/gcc.dg/pr117724.c
+new file mode 100644
+index 000000000000..d631daeb644d
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/pr117724.c
+@@ -0,0 +1,16 @@
++/* { dg-do compile } */
++/* { dg-options "-g" } */
++
++struct {
++  unsigned long len;
++  unsigned long size;
++  char data[];
++};			/* { dg-warning "unnamed struct" } */
++struct {
++  struct {
++    unsigned long len;
++    unsigned long size;
++    char data[6];
++  };
++};			/* { dg-warning "unnamed struct" } */
++
+diff --git a/gcc/tree.cc b/gcc/tree.cc
+index 83a03374a325..da4b7f5daa8c 100644
+--- a/gcc/tree.cc
++++ b/gcc/tree.cc
+@@ -13837,11 +13837,13 @@ type_with_interoperable_signedness (const_tree type)
+    verifier.  If TRUST_TYPE_CANONICAL we do not look into structure of types
+    that have TYPE_CANONICAL defined and assume them equivalent.  This is useful
+    only for LTO because only in these cases TYPE_CANONICAL equivalence
+-   correspond to one defined by gimple_canonical_types_compatible_p.  */
+-
++   correspond to one defined by gimple_canonical_types_compatible_p.
++   If IGNORE_SIZE, we allow a mismatch of the mode and the number of
++   elements for arrays.  */
+ bool
+ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
+-				     bool trust_type_canonical)
++				     bool trust_type_canonical,
++				     bool ignore_size)
+ {
+   /* Type variants should be same as the main variant.  When not doing sanity
+      checking to verify this fact, go to main variants and save some work.  */
+@@ -13914,8 +13916,12 @@ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
+       || TREE_CODE (t1) == NULLPTR_TYPE)
+     return true;
+ 
+-  /* Can't be the same type if they have different mode.  */
+-  if (TYPE_MODE (t1) != TYPE_MODE (t2))
++  /* Can't be compatible types if they have different mode.  Because of
++     flexible array members, we allow mismatching modes for structures or
++     unions and for arrays when we ignore the size.  */
++  if (!RECORD_OR_UNION_TYPE_P (t1)
++      && (!ignore_size || TREE_CODE (t1) != ARRAY_TYPE)
++      && (TYPE_MODE (t1) != TYPE_MODE (t2)))
+     return false;
+ 
+   /* Non-aggregate types can be handled cheaply.  */
+@@ -13966,15 +13972,19 @@ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
+     {
+     case ARRAY_TYPE:
+       /* Array types are the same if the element types are the same and
+-	 the number of elements are the same.  */
++	 minimum and maximum index are the same.  */
+       if (!gimple_canonical_types_compatible_p (TREE_TYPE (t1), TREE_TYPE (t2),
+-						trust_type_canonical)
++						trust_type_canonical,
++						ignore_size)
+ 	  || TYPE_STRING_FLAG (t1) != TYPE_STRING_FLAG (t2)
+ 	  || TYPE_REVERSE_STORAGE_ORDER (t1) != TYPE_REVERSE_STORAGE_ORDER (t2)
+ 	  || TYPE_NONALIASED_COMPONENT (t1) != TYPE_NONALIASED_COMPONENT (t2))
+ 	return false;
+       else
+ 	{
++	  if (ignore_size)
++	    return true;
++
+ 	  tree i1 = TYPE_DOMAIN (t1);
+ 	  tree i2 = TYPE_DOMAIN (t2);
+ 
+@@ -14060,23 +14070,36 @@ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
+ 	     f1 || f2;
+ 	     f1 = TREE_CHAIN (f1), f2 = TREE_CHAIN (f2))
+ 	  {
+-	    /* Skip non-fields and zero-sized fields.  */
++	    /* Skip non-fields and zero-sized fields, except zero-sized
++	       arrays at the end.  */
+ 	    while (f1 && (TREE_CODE (f1) != FIELD_DECL
+ 			  || (DECL_SIZE (f1)
+-			      && integer_zerop (DECL_SIZE (f1)))))
++			      && integer_zerop (DECL_SIZE (f1))
++			      && (TREE_CHAIN (f1)
++				  || TREE_CODE (TREE_TYPE (f1))
++				     != ARRAY_TYPE))))
+ 	      f1 = TREE_CHAIN (f1);
+ 	    while (f2 && (TREE_CODE (f2) != FIELD_DECL
+ 			  || (DECL_SIZE (f2)
+-			      && integer_zerop (DECL_SIZE (f2)))))
++			      && integer_zerop (DECL_SIZE (f2))
++			      && (TREE_CHAIN (f2)
++				  || TREE_CODE (TREE_TYPE (f2))
++				     != ARRAY_TYPE))))
+ 	      f2 = TREE_CHAIN (f2);
+ 	    if (!f1 || !f2)
+ 	      break;
+-	    /* The fields must have the same name, offset and type.  */
++
++	    tree t1 = TREE_TYPE (f1);
++	    tree t2 = TREE_TYPE (f2);
++
++	    /* If the last element is an array, we allow a mismatch in size. */
++	    bool ignore_size = (TREE_CHAIN (f1) == NULL_TREE
++				&& TREE_CODE (t1) == ARRAY_TYPE);
++
+ 	    if (DECL_NONADDRESSABLE_P (f1) != DECL_NONADDRESSABLE_P (f2)
+ 		|| !gimple_compare_field_offset (f1, f2)
+ 		|| !gimple_canonical_types_compatible_p
+-		      (TREE_TYPE (f1), TREE_TYPE (f2),
+-		       trust_type_canonical))
++		      (t1, t2, trust_type_canonical, ignore_size))
+ 	      return false;
+ 	  }
+ 
+@@ -14220,6 +14243,10 @@ verify_type (const_tree t)
+     }
+ 
+   if (COMPLETE_TYPE_P (t) && TYPE_CANONICAL (t)
++      /* We allow a mismatch for structure or union because of
++	 flexible array members.  */
++      && !RECORD_OR_UNION_TYPE_P (t)
++      && !RECORD_OR_UNION_TYPE_P (TYPE_CANONICAL (t))
+       && TYPE_MODE (t) != TYPE_MODE (TYPE_CANONICAL (t)))
+     {
+       error ("%<TYPE_MODE%> of %<TYPE_CANONICAL%> is not compatible");
+diff --git a/gcc/tree.h b/gcc/tree.h
+index 75054839d9b6..6608754a3e20 100644
+--- a/gcc/tree.h
++++ b/gcc/tree.h
+@@ -5844,7 +5844,8 @@ extern unsigned int tree_map_base_hash (const void *);
+ extern bool tree_map_base_marked_p (const void *);
+ extern void DEBUG_FUNCTION verify_type (const_tree t);
+ extern bool gimple_canonical_types_compatible_p (const_tree, const_tree,
+-						 bool trust_type_canonical = true);
++						 bool trust_type_canonical = true,
++						 bool ignore_size = false);
+ extern bool type_with_interoperable_signedness (const_tree);
+ extern bitmap get_nonnull_args (const_tree);
+ extern int get_range_pos_neg (tree);
+
+base-commit: 6205144d6b566f32a58c4fa4f5e7e2343ad07c62
+-- 
+2.47.1
+
diff --git a/15.0.0/gentoo/75_all_PR117724-testsuite-fix-LTO-flags-in-pr112716.c.patch b/15.0.0/gentoo/75_all_PR117724-testsuite-fix-LTO-flags-in-pr112716.c.patch
new file mode 100644
index 0000000..f36840e
--- /dev/null
+++ b/15.0.0/gentoo/75_all_PR117724-testsuite-fix-LTO-flags-in-pr112716.c.patch
@@ -0,0 +1,27 @@
+From 2f961c392ab359286ef1350d37e50e7841773d7b Mon Sep 17 00:00:00 2001
+Message-ID: <2f961c392ab359286ef1350d37e50e7841773d7b.1733713329.git.sam@gentoo.org>
+In-Reply-To: <e1d3dfa0936ca5b50c87f6ddf5347fa401a703f6.1733713329.git.sam@gentoo.org>
+References: <e1d3dfa0936ca5b50c87f6ddf5347fa401a703f6.1733713329.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Mon, 9 Dec 2024 03:01:47 +0000
+Subject: [PATCH 2/2] testsuite: fix LTO flags in pr112716.c
+
+---
+ gcc/testsuite/gcc.dg/pr112716.c | 3 ++-
+ 1 file changed, 2 insertions(+), 1 deletion(-)
+
+diff --git a/gcc/testsuite/gcc.dg/pr112716.c b/gcc/testsuite/gcc.dg/pr112716.c
+index 109dd252f0d6..873eedaafd18 100644
+--- a/gcc/testsuite/gcc.dg/pr112716.c
++++ b/gcc/testsuite/gcc.dg/pr112716.c
+@@ -1,5 +1,6 @@
+ /* { dg-do compile } */
+-/* { dg-options "-lfto -O2" } */
++/* { dg-options "-flto -O2" } */
++/* { dg-require-effective-target lto } */
+ 
+ #define T1 int[n]
+ #define T2 int[n]
+-- 
+2.47.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index b42dfc7..048d96a 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,8 @@
+31	???
+
+	+ 74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
+	+ 75_all_PR117724-testsuite-fix-LTO-flags-in-pr112716.c.patch
+
 30	8 December 2024
 
 	+ 73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-10  5:07 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-10  5:07 UTC (permalink / raw
  To: gentoo-commits
commit:     35045208b613bd86d21415331da51d235ee5e6e7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 10 05:07:05 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Dec 10 05:07:05 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=35045208
15.0.0: add nvptx bashism patch
Bug: https://gcc.gnu.org/PR117854
Bug: https://bugs.gentoo.org/945296
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...tx-fix-bashisms-with-gen-copyright.sh-use.patch | 68 ++++++++++++++++++++++
 15.0.0/gentoo/README.history                       |  1 +
 2 files changed, 69 insertions(+)
diff --git a/15.0.0/gentoo/76_all_PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch b/15.0.0/gentoo/76_all_PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch
new file mode 100644
index 0000000..6011313
--- /dev/null
+++ b/15.0.0/gentoo/76_all_PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch
@@ -0,0 +1,68 @@
+From f6959883aecd1500698ea969de631ffa010ce833 Mon Sep 17 00:00:00 2001
+Message-ID: <f6959883aecd1500698ea969de631ffa010ce833.1733807152.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Fri, 6 Dec 2024 09:11:11 +0000
+Subject: [PATCH] config: nvptx: fix bashisms with gen-copyright.sh use
+
+Providing parameters to `.` when sourcing is a bashism and not supported
+by POSIX shell which causes a build failure when compiling a toolchain
+for nvptx-none with dash as /bin/sh.
+
+gen-copyright.sh takes a parameter for the format of copyright notice
+required. Switch that to using an environment variable `NVPTX_GEN_COPYRIGHT`,
+although this could be changed to a function if desired (just more churn
+in gen-copyright.sh then).
+
+gcc/ChangeLog:
+	PR target/117854
+
+	* config/nvptx/gen-copyright.sh: Read NVPTX_GEN_COPYRIGHT envvar.
+	* config/nvptx/gen-h.sh: Set NVPTX_GEN_COPYRIGHT.
+	* config/nvptx/gen-opt.sh: Ditto.
+---
+ gcc/config/nvptx/gen-copyright.sh | 2 +-
+ gcc/config/nvptx/gen-h.sh         | 2 +-
+ gcc/config/nvptx/gen-opt.sh       | 2 +-
+ 3 files changed, 3 insertions(+), 3 deletions(-)
+
+diff --git a/gcc/config/nvptx/gen-copyright.sh b/gcc/config/nvptx/gen-copyright.sh
+index d0a86acb832c..b140de0eb76d 100644
+--- a/gcc/config/nvptx/gen-copyright.sh
++++ b/gcc/config/nvptx/gen-copyright.sh
+@@ -18,7 +18,7 @@
+ # along with GCC; see the file COPYING3.  If not see
+ # <http://www.gnu.org/licenses/>.
+ 
+-style="$1"
++style="${1:-${NVPTX_GEN_COPYRIGHT}}"
+ case $style in
+     opt)
+     ;;
+diff --git a/gcc/config/nvptx/gen-h.sh b/gcc/config/nvptx/gen-h.sh
+index bc4ce9af1e2a..a5c18d864504 100644
+--- a/gcc/config/nvptx/gen-h.sh
++++ b/gcc/config/nvptx/gen-h.sh
+@@ -36,7 +36,7 @@ EOF
+ # Separator.
+ echo
+ 
+-. $gen_copyright_sh c
++NVPTX_GEN_COPYRIGHT=c . $gen_copyright_sh
+ 
+ # Separator.
+ echo
+diff --git a/gcc/config/nvptx/gen-opt.sh b/gcc/config/nvptx/gen-opt.sh
+index 103bcddc02b5..40c949425f27 100644
+--- a/gcc/config/nvptx/gen-opt.sh
++++ b/gcc/config/nvptx/gen-opt.sh
+@@ -40,7 +40,7 @@ EOF
+ # Separator.
+ echo
+ 
+-. $gen_copyright_sh opt
++NVPTX_GEN_COPYRIGHT=opt . $gen_copyright_sh
+ 
+ # Not emitting the following here (in addition to having it in 'nvptx.opt'), as
+ # we'll otherwise run into:
+-- 
+2.47.1
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 048d96a..adc1fef 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -2,6 +2,7 @@
 
 	+ 74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
 	+ 75_all_PR117724-testsuite-fix-LTO-flags-in-pr112716.c.patch
+	+ 76_all_PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch
 
 30	8 December 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-10  5:11 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-10  5:11 UTC (permalink / raw
  To: gentoo-commits
commit:     f41e17d0b106cc664c051f599c09ce696a3ab66d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 10 05:11:17 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Dec 10 05:11:17 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=f41e17d0
15.0.0: update -fstack-clash-protection patch for offload
Bug: https://bugs.gentoo.org/945296
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/24_all_DEF_GENTOO_SCP-fstack-clash-protection.patch | 2 +-
 15.0.0/gentoo/README.history                                      | 1 +
 2 files changed, 2 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/24_all_DEF_GENTOO_SCP-fstack-clash-protection.patch b/15.0.0/gentoo/24_all_DEF_GENTOO_SCP-fstack-clash-protection.patch
index b13215d..b2cc852 100644
--- a/15.0.0/gentoo/24_all_DEF_GENTOO_SCP-fstack-clash-protection.patch
+++ b/15.0.0/gentoo/24_all_DEF_GENTOO_SCP-fstack-clash-protection.patch
@@ -19,7 +19,7 @@ We add -fstack-clash-protection if requested
  
 +/* Default value for flag_clash_protector when flag_clash_protector is
 +   initialized to -1.  */
-+#ifdef DEF_GENTOO_SCP
++#if defined(DEF_GENTOO_SCP) && !defined(ACCEL_COMPILER)
 +#define DEFAULT_FLAG_SCP 1
 +#endif
 +#ifndef DEFAULT_FLAG_SCP
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index adc1fef..63fd877 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 31	???
 
+	U 24_all_DEF_GENTOO_SCP-fstack-clash-protection.patch
 	+ 74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
 	+ 75_all_PR117724-testsuite-fix-LTO-flags-in-pr112716.c.patch
 	+ 76_all_PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-10  5:13 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-10  5:13 UTC (permalink / raw
  To: gentoo-commits
commit:     ec76a392e824bb1abe5f2d390d4bdbd96ee50040
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 10 05:12:51 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Dec 10 05:13:01 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ec76a392
15.0.0: update -D_GLIBCXX_ASSERTIONS patch for offload
Bug: https://bugs.gentoo.org/945296
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/15_all_DEF_GENTOO_GLIBCXX_ASSERTIONS.patch | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/15_all_DEF_GENTOO_GLIBCXX_ASSERTIONS.patch b/15.0.0/gentoo/15_all_DEF_GENTOO_GLIBCXX_ASSERTIONS.patch
index 2daf73b..8e9e19b 100644
--- a/15.0.0/gentoo/15_all_DEF_GENTOO_GLIBCXX_ASSERTIONS.patch
+++ b/15.0.0/gentoo/15_all_DEF_GENTOO_GLIBCXX_ASSERTIONS.patch
@@ -5,7 +5,7 @@ https://bugs.gentoo.org/876895
  	  cpp_define (pfile, "__cpp_rtti=199711L");
  	}
  
-+      #ifdef DEF_GENTOO_GLIBCXX_ASSERTIONS
++      #if defined(DEF_GENTOO_GLIBCXX_ASSERTIONS) && !defined(ACCEL_COMPILER)
 +	  cpp_define (pfile, "_GLIBCXX_ASSERTIONS");
 +      #endif
 +
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-10  5:19 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-10  5:19 UTC (permalink / raw
  To: gentoo-commits
commit:     95a0fb3364df529328991a746a47ea9bd3ef4e23
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 10 05:18:49 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Dec 10 05:19:16 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=95a0fb33
15.0.0: update -fcf-protection patch for offload
Bug: https://bugs.gentoo.org/945296
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/26_all_enable-cet.patch | 2 +-
 15.0.0/gentoo/README.history          | 1 +
 2 files changed, 2 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/26_all_enable-cet.patch b/15.0.0/gentoo/26_all_enable-cet.patch
index be772d0..6d977cf 100644
--- a/15.0.0/gentoo/26_all_enable-cet.patch
+++ b/15.0.0/gentoo/26_all_enable-cet.patch
@@ -67,7 +67,7 @@ Only supported on amd64.
 +
 +   We use a new option (EXTRA_OPTIONS_CF) here to avoid turning
 +   this on accidentally for other arches. */
-+#ifdef EXTRA_OPTIONS_CF
++#if defined(EXTRA_OPTIONS_CF) && !defined(ACCEL_COMPILER)
 +#define DEFAULT_FLAG_CF_SPEC " %{!m16:%{!m32:%{!fcf-protection*:%{!fno-cf-protection:-fcf-protection}}}} -foffload-options=-fcf-protection=none"
 +#endif
 +#ifndef DEFAULT_FLAG_CF_SPEC
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 63fd877..639981b 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 31	???
 
 	U 24_all_DEF_GENTOO_SCP-fstack-clash-protection.patch
+	U 26_all_enable-cet.patch
 	+ 74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
 	+ 75_all_PR117724-testsuite-fix-LTO-flags-in-pr112716.c.patch
 	+ 76_all_PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-10 14:55 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-10 14:55 UTC (permalink / raw
  To: gentoo-commits
commit:     236e7b39fc0545df14b4df5e45d37c1b844ddc23
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 10 14:55:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Dec 10 14:55:42 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=236e7b39
15.0.0: update C23 FAM patches
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...mpatibility-for-types-with-flexible-array.patch | 304 ++-------------------
 ...atibility-for-types-with-flexible-array-2.patch | 250 +++++++++++++++++
 ...724-testsuite-fix-LTO-flags-in-pr112716.c.patch |  27 --
 15.0.0/gentoo/README.history                       |   2 +-
 4 files changed, 278 insertions(+), 305 deletions(-)
diff --git a/15.0.0/gentoo/74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch b/15.0.0/gentoo/74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
index 3c20493..1b682ad 100644
--- a/15.0.0/gentoo/74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
+++ b/15.0.0/gentoo/74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
@@ -1,75 +1,35 @@
-From e1d3dfa0936ca5b50c87f6ddf5347fa401a703f6 Mon Sep 17 00:00:00 2001
-Message-ID: <e1d3dfa0936ca5b50c87f6ddf5347fa401a703f6.1733713329.git.sam@gentoo.org>
+From 511aac7c85e6cc2ce474e1169dadd17c570743ec Mon Sep 17 00:00:00 2001
+Message-ID: <511aac7c85e6cc2ce474e1169dadd17c570743ec.1733842378.git.sam@gentoo.org>
 From: Martin Uecker <uecker@tugraz.at>
-Date: Mon, 9 Dec 2024 00:11:58 +0100
+Date: Tue, 10 Dec 2024 13:29:27 +0100
 Subject: [PATCH 1/2] Fix type compatibility for types with flexible array
- member [PR113688,PR114014,PR117724]
+ member [PR113688,PR114713,PR117724]
 MIME-Version: 1.0
 Content-Type: text/plain; charset=UTF-8
 Content-Transfer-Encoding: 8bit
 
-Hi Richard,
-
-this is another version.  It now adds an "ignore_size" flag
-to gimple_canonical_types_compatible_p and uses this instead
-of having the complicated special case for arrays at the
-end.  Also zero-sized members are now ignored again, except
-if they are arrays at the end where then only the size is
-ignored.  This can still be stricter than before for the 
-case where there are zero-sized arrays at the end (e.g.
-before element type could differ).
-
-Martin
+As requested, I split up into one part for the TYPE_MODE and 
+another one for the array size to help with git bisecting.  This
+is the first part.
 
 Bootstrapped and regression tested on x86_64.
 
-Fix type compatibility for types with flexible array member [PR113688,PR114014,PR117724]
-
-    verify_type checks the compatibility of TYPE_CANONICAL using
-    gimple_canonical_types_compatible_p.   But it is stricter than what the
-    C standard requires and therefor inconsistent with how TYPE_CANONICAL is set
-    in the C FE.  Here, the logic is changed to ignore the array size when it
-    is the last element of a structure or union.  To not get errors because of
-    an inconsistent number of members, zero-sized arrays which are the last
-    element are not ignored anymore when checking the fields of a struct (which
-    in this particular case is stricter than what was done before).  Finally,
-    exceptions are added that allow the TYPE_MODE of a type with an array as
-    last member and of such arrays to differ from another compatible type.
+Allow the TYPE_MODE of a type with an array as last member to differ from
+another compatible type.
 
-            PR c/112716
-            PR c/113688
-            PR c/114014
-            PR c/117724
+gcc/ChangeLog:
+        * tree.cc (gimple_canonical_types_compatible_p): Add exception.
+        (verify_type): Add exception.
 
-    gcc/ChangeLog:
-            * tree.cc (gimple_canonical_types_compatible_p): Add
-              `ignore_size' parameter and revise logic.
-            (verify_type): Add exceptions.
-
-    gcc/lto/ChangeLog:
-            * lto-common.cc (hash_canonical_type): Add exceptions.
-
-    gcc/testsuite/ChangeLog:
-            * gcc.dg/pr112716.c: New test.
-            * gcc.dg/pr113688.c: New test.
-            * gcc.dg/pr114014.c: New test.
-            * gcc.dg/pr117724.c: New test.
+gcc/lto/ChangeLog:
+        * lto-common.cc (hash_canonical_type): Add exception.
 ---
- gcc/lto/lto-common.cc           |  9 ++++--
- gcc/testsuite/gcc.dg/pr112716.c | 40 +++++++++++++++++++++++++
- gcc/testsuite/gcc.dg/pr113688.c |  8 +++++
- gcc/testsuite/gcc.dg/pr114014.c | 14 +++++++++
- gcc/testsuite/gcc.dg/pr117724.c | 16 ++++++++++
- gcc/tree.cc                     | 53 +++++++++++++++++++++++++--------
- gcc/tree.h                      |  3 +-
- 7 files changed, 127 insertions(+), 16 deletions(-)
- create mode 100644 gcc/testsuite/gcc.dg/pr112716.c
- create mode 100644 gcc/testsuite/gcc.dg/pr113688.c
- create mode 100644 gcc/testsuite/gcc.dg/pr114014.c
- create mode 100644 gcc/testsuite/gcc.dg/pr117724.c
+ gcc/lto/lto-common.cc |  3 ++-
+ gcc/tree.cc           | 12 +++++++++---
+ 2 files changed, 11 insertions(+), 4 deletions(-)
 
 diff --git a/gcc/lto/lto-common.cc b/gcc/lto/lto-common.cc
-index 86a309f92b40..f65a9d1c7b6f 100644
+index 86a309f92b40..940502099128 100644
 --- a/gcc/lto/lto-common.cc
 +++ b/gcc/lto/lto-common.cc
 @@ -254,7 +254,8 @@ hash_canonical_type (tree type)
@@ -82,143 +42,11 @@ index 86a309f92b40..f65a9d1c7b6f 100644
  
    /* Incorporate common features of numerical types.  */
    if (INTEGRAL_TYPE_P (type)
-@@ -332,7 +333,11 @@ hash_canonical_type (tree type)
- 	    && (! DECL_SIZE (f)
- 		|| ! integer_zerop (DECL_SIZE (f))))
- 	  {
--	    iterative_hash_canonical_type (TREE_TYPE (f), hstate);
-+	    tree t = TREE_TYPE (f);
-+	    if (!TREE_CHAIN (f)
-+		&& TREE_CODE (t) == ARRAY_TYPE)
-+	      t = TREE_TYPE  (t);
-+	    iterative_hash_canonical_type (t, hstate);
- 	    nf++;
- 	  }
- 
-diff --git a/gcc/testsuite/gcc.dg/pr112716.c b/gcc/testsuite/gcc.dg/pr112716.c
-new file mode 100644
-index 000000000000..109dd252f0d6
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/pr112716.c
-@@ -0,0 +1,40 @@
-+/* { dg-do compile } */
-+/* { dg-options "-lfto -O2" } */
-+
-+#define T1 int[n]
-+#define T2 int[n]
-+
-+// TU 1
-+void bar(void*);
-+
-+[[gnu::noinline,gnu::noipa]]
-+int foo(void *p, void *q)
-+{
-+	int n = 5;
-+	struct foo { int x; typeof(T1) y; } *p2 = p;
-+	p2->x = 1;
-+	bar(q);
-+	return p2->x;
-+}
-+
-+int main()
-+{
-+	int n = 5;
-+	void *p = __builtin_malloc(sizeof(struct foo { int x; typeof(T1) y; }));
-+
-+	if (!p)
-+		return 0;
-+
-+	if (2 != foo(p, p))
-+		__builtin_abort();
-+
-+	return 0;
-+}
-+// TU 2
-+void bar(void* q)
-+{
-+	int n = 5;
-+	struct foo { int x; typeof(T2) y; } *q2 = q;
-+	q2->x = 2;
-+}
-+
-diff --git a/gcc/testsuite/gcc.dg/pr113688.c b/gcc/testsuite/gcc.dg/pr113688.c
-new file mode 100644
-index 000000000000..8dee8c86f1bf
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/pr113688.c
-@@ -0,0 +1,8 @@
-+/* { dg-do compile } */
-+/* { dg-options "-g" } */
-+
-+struct S{int x,y[1];}*a;
-+int main(void){
-+	struct S{int x,y[];};
-+}
-+
-diff --git a/gcc/testsuite/gcc.dg/pr114014.c b/gcc/testsuite/gcc.dg/pr114014.c
-new file mode 100644
-index 000000000000..1531ffab1b75
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/pr114014.c
-@@ -0,0 +1,14 @@
-+/* PR c/114014
-+ * { dg-do compile }
-+ * { dg-options "-std=gnu23 -g" } */
-+
-+struct r {
-+  int a;
-+  char b[];
-+};
-+struct r {
-+  int a;
-+  char b[0];
-+};
-+
-+
-diff --git a/gcc/testsuite/gcc.dg/pr117724.c b/gcc/testsuite/gcc.dg/pr117724.c
-new file mode 100644
-index 000000000000..d631daeb644d
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/pr117724.c
-@@ -0,0 +1,16 @@
-+/* { dg-do compile } */
-+/* { dg-options "-g" } */
-+
-+struct {
-+  unsigned long len;
-+  unsigned long size;
-+  char data[];
-+};			/* { dg-warning "unnamed struct" } */
-+struct {
-+  struct {
-+    unsigned long len;
-+    unsigned long size;
-+    char data[6];
-+  };
-+};			/* { dg-warning "unnamed struct" } */
-+
 diff --git a/gcc/tree.cc b/gcc/tree.cc
-index 83a03374a325..da4b7f5daa8c 100644
+index 83a03374a325..1391af6bd4c3 100644
 --- a/gcc/tree.cc
 +++ b/gcc/tree.cc
-@@ -13837,11 +13837,13 @@ type_with_interoperable_signedness (const_tree type)
-    verifier.  If TRUST_TYPE_CANONICAL we do not look into structure of types
-    that have TYPE_CANONICAL defined and assume them equivalent.  This is useful
-    only for LTO because only in these cases TYPE_CANONICAL equivalence
--   correspond to one defined by gimple_canonical_types_compatible_p.  */
--
-+   correspond to one defined by gimple_canonical_types_compatible_p.
-+   If IGNORE_SIZE, we allow a mismatch of the mode and the number of
-+   elements for arrays.  */
- bool
- gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
--				     bool trust_type_canonical)
-+				     bool trust_type_canonical,
-+				     bool ignore_size)
- {
-   /* Type variants should be same as the main variant.  When not doing sanity
-      checking to verify this fact, go to main variants and save some work.  */
-@@ -13914,8 +13916,12 @@ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
+@@ -13914,8 +13914,11 @@ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
        || TREE_CODE (t1) == NULLPTR_TYPE)
      return true;
  
@@ -226,81 +54,17 @@ index 83a03374a325..da4b7f5daa8c 100644
 -  if (TYPE_MODE (t1) != TYPE_MODE (t2))
 +  /* Can't be compatible types if they have different mode.  Because of
 +     flexible array members, we allow mismatching modes for structures or
-+     unions and for arrays when we ignore the size.  */
++     unions.  */
 +  if (!RECORD_OR_UNION_TYPE_P (t1)
-+      && (!ignore_size || TREE_CODE (t1) != ARRAY_TYPE)
-+      && (TYPE_MODE (t1) != TYPE_MODE (t2)))
++      && TYPE_MODE (t1) != TYPE_MODE (t2))
      return false;
  
    /* Non-aggregate types can be handled cheaply.  */
-@@ -13966,15 +13972,19 @@ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
-     {
-     case ARRAY_TYPE:
-       /* Array types are the same if the element types are the same and
--	 the number of elements are the same.  */
-+	 minimum and maximum index are the same.  */
-       if (!gimple_canonical_types_compatible_p (TREE_TYPE (t1), TREE_TYPE (t2),
--						trust_type_canonical)
-+						trust_type_canonical,
-+						ignore_size)
- 	  || TYPE_STRING_FLAG (t1) != TYPE_STRING_FLAG (t2)
- 	  || TYPE_REVERSE_STORAGE_ORDER (t1) != TYPE_REVERSE_STORAGE_ORDER (t2)
- 	  || TYPE_NONALIASED_COMPONENT (t1) != TYPE_NONALIASED_COMPONENT (t2))
- 	return false;
-       else
- 	{
-+	  if (ignore_size)
-+	    return true;
-+
- 	  tree i1 = TYPE_DOMAIN (t1);
- 	  tree i2 = TYPE_DOMAIN (t2);
- 
-@@ -14060,23 +14070,36 @@ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
- 	     f1 || f2;
- 	     f1 = TREE_CHAIN (f1), f2 = TREE_CHAIN (f2))
- 	  {
--	    /* Skip non-fields and zero-sized fields.  */
-+	    /* Skip non-fields and zero-sized fields, except zero-sized
-+	       arrays at the end.  */
- 	    while (f1 && (TREE_CODE (f1) != FIELD_DECL
- 			  || (DECL_SIZE (f1)
--			      && integer_zerop (DECL_SIZE (f1)))))
-+			      && integer_zerop (DECL_SIZE (f1))
-+			      && (TREE_CHAIN (f1)
-+				  || TREE_CODE (TREE_TYPE (f1))
-+				     != ARRAY_TYPE))))
- 	      f1 = TREE_CHAIN (f1);
- 	    while (f2 && (TREE_CODE (f2) != FIELD_DECL
- 			  || (DECL_SIZE (f2)
--			      && integer_zerop (DECL_SIZE (f2)))))
-+			      && integer_zerop (DECL_SIZE (f2))
-+			      && (TREE_CHAIN (f2)
-+				  || TREE_CODE (TREE_TYPE (f2))
-+				     != ARRAY_TYPE))))
- 	      f2 = TREE_CHAIN (f2);
- 	    if (!f1 || !f2)
- 	      break;
--	    /* The fields must have the same name, offset and type.  */
-+
-+	    tree t1 = TREE_TYPE (f1);
-+	    tree t2 = TREE_TYPE (f2);
-+
-+	    /* If the last element is an array, we allow a mismatch in size. */
-+	    bool ignore_size = (TREE_CHAIN (f1) == NULL_TREE
-+				&& TREE_CODE (t1) == ARRAY_TYPE);
-+
- 	    if (DECL_NONADDRESSABLE_P (f1) != DECL_NONADDRESSABLE_P (f2)
- 		|| !gimple_compare_field_offset (f1, f2)
- 		|| !gimple_canonical_types_compatible_p
--		      (TREE_TYPE (f1), TREE_TYPE (f2),
--		       trust_type_canonical))
-+		      (t1, t2, trust_type_canonical, ignore_size))
- 	      return false;
- 	  }
- 
-@@ -14220,6 +14243,10 @@ verify_type (const_tree t)
+@@ -14218,8 +14221,11 @@ verify_type (const_tree t)
+       debug_tree (ct);
+       error_found = true;
      }
- 
+-
    if (COMPLETE_TYPE_P (t) && TYPE_CANONICAL (t)
 +      /* We allow a mismatch for structure or union because of
 +	 flexible array members.  */
@@ -309,22 +73,8 @@ index 83a03374a325..da4b7f5daa8c 100644
        && TYPE_MODE (t) != TYPE_MODE (TYPE_CANONICAL (t)))
      {
        error ("%<TYPE_MODE%> of %<TYPE_CANONICAL%> is not compatible");
-diff --git a/gcc/tree.h b/gcc/tree.h
-index 75054839d9b6..6608754a3e20 100644
---- a/gcc/tree.h
-+++ b/gcc/tree.h
-@@ -5844,7 +5844,8 @@ extern unsigned int tree_map_base_hash (const void *);
- extern bool tree_map_base_marked_p (const void *);
- extern void DEBUG_FUNCTION verify_type (const_tree t);
- extern bool gimple_canonical_types_compatible_p (const_tree, const_tree,
--						 bool trust_type_canonical = true);
-+						 bool trust_type_canonical = true,
-+						 bool ignore_size = false);
- extern bool type_with_interoperable_signedness (const_tree);
- extern bitmap get_nonnull_args (const_tree);
- extern int get_range_pos_neg (tree);
 
-base-commit: 6205144d6b566f32a58c4fa4f5e7e2343ad07c62
+base-commit: 34dfb30ca8dba6bc184e563b0ddc26a5239294e3
 -- 
 2.47.1
 
diff --git a/15.0.0/gentoo/75_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array-2.patch b/15.0.0/gentoo/75_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array-2.patch
new file mode 100644
index 0000000..1f35b83
--- /dev/null
+++ b/15.0.0/gentoo/75_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array-2.patch
@@ -0,0 +1,250 @@
+From 4bc7c98e86392a36f75029eabbe096d1bf9e85b5 Mon Sep 17 00:00:00 2001
+Message-ID: <4bc7c98e86392a36f75029eabbe096d1bf9e85b5.1733842378.git.sam@gentoo.org>
+In-Reply-To: <511aac7c85e6cc2ce474e1169dadd17c570743ec.1733842378.git.sam@gentoo.org>
+References: <511aac7c85e6cc2ce474e1169dadd17c570743ec.1733842378.git.sam@gentoo.org>
+From: Martin Uecker <uecker@tugraz.at>
+Date: Tue, 10 Dec 2024 13:31:50 +0100
+Subject: [PATCH 2/2] Fix type compatibility for types with flexible array
+ member [PR113688,PR114713,PR117724]
+
+The second part now only contains the changes for array size.
+
+I added back a special case for this instead of having the
+'ignore_size' flag (which I would nevertheless assume might be
+needed in the future when matching pointer types).
+
+In this version, I added an exception to the special case to ignore
+the case were both are zero-sized arrays, because this seems to be
+the only case were the new code would otherwise be stricter than the
+old code.
+
+I also replaced/fixed one test where I accidentally included a similar
+test for another closely related bug involving VLA types.
+
+Bootstrapped and regression tested on x86_64.
+
+For checking or computing TYPE_CANONICAL, ignore the array size when it is
+the last element of a structure or union.  To not get errors because of
+an inconsistent number of members, zero-sized arrays which are the last
+element are not ignored anymore when checking the fields of a struct.
+
+	PR c/113688
+	PR c/114014
+	PR c/114713
+	PR c/117724
+
+gcc/ChangeLog:
+	* tree.cc (gimple_canonical_types_compatible_p): Add exception.
+
+gcc/lto/ChangeLog:
+	* lto-common.cc (hash_canonical_type): Add exception.
+
+gcc/testsuite/ChangeLog:
+	* gcc.dg/pr113688.c: New test.
+	* gcc.dg/pr114014.c: New test.
+	* gcc.dg/pr114713.c: New test.
+	* gcc.dg/pr117724.c: New test.
+---
+ gcc/lto/lto-common.cc           |  6 +++++-
+ gcc/testsuite/gcc.dg/pr113688.c |  8 +++++++
+ gcc/testsuite/gcc.dg/pr114014.c | 14 ++++++++++++
+ gcc/testsuite/gcc.dg/pr114713.c | 35 ++++++++++++++++++++++++++++++
+ gcc/testsuite/gcc.dg/pr117724.c | 16 ++++++++++++++
+ gcc/tree.cc                     | 38 ++++++++++++++++++++++++++-------
+ 6 files changed, 108 insertions(+), 9 deletions(-)
+ create mode 100644 gcc/testsuite/gcc.dg/pr113688.c
+ create mode 100644 gcc/testsuite/gcc.dg/pr114014.c
+ create mode 100644 gcc/testsuite/gcc.dg/pr114713.c
+ create mode 100644 gcc/testsuite/gcc.dg/pr117724.c
+
+diff --git a/gcc/lto/lto-common.cc b/gcc/lto/lto-common.cc
+index 940502099128..f65a9d1c7b6f 100644
+--- a/gcc/lto/lto-common.cc
++++ b/gcc/lto/lto-common.cc
+@@ -333,7 +333,11 @@ hash_canonical_type (tree type)
+ 	    && (! DECL_SIZE (f)
+ 		|| ! integer_zerop (DECL_SIZE (f))))
+ 	  {
+-	    iterative_hash_canonical_type (TREE_TYPE (f), hstate);
++	    tree t = TREE_TYPE (f);
++	    if (!TREE_CHAIN (f)
++		&& TREE_CODE (t) == ARRAY_TYPE)
++	      t = TREE_TYPE  (t);
++	    iterative_hash_canonical_type (t, hstate);
+ 	    nf++;
+ 	  }
+ 
+diff --git a/gcc/testsuite/gcc.dg/pr113688.c b/gcc/testsuite/gcc.dg/pr113688.c
+new file mode 100644
+index 000000000000..8dee8c86f1bf
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/pr113688.c
+@@ -0,0 +1,8 @@
++/* { dg-do compile } */
++/* { dg-options "-g" } */
++
++struct S{int x,y[1];}*a;
++int main(void){
++	struct S{int x,y[];};
++}
++
+diff --git a/gcc/testsuite/gcc.dg/pr114014.c b/gcc/testsuite/gcc.dg/pr114014.c
+new file mode 100644
+index 000000000000..1531ffab1b75
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/pr114014.c
+@@ -0,0 +1,14 @@
++/* PR c/114014
++ * { dg-do compile }
++ * { dg-options "-std=gnu23 -g" } */
++
++struct r {
++  int a;
++  char b[];
++};
++struct r {
++  int a;
++  char b[0];
++};
++
++
+diff --git a/gcc/testsuite/gcc.dg/pr114713.c b/gcc/testsuite/gcc.dg/pr114713.c
+new file mode 100644
+index 000000000000..1f0ad39c433c
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/pr114713.c
+@@ -0,0 +1,35 @@
++/* { dg-do run } */
++/* { dg-require-effective-target lto } */
++/* { dg-options "-flto -O2" } */
++
++struct foo { int x; char a[]; };
++
++void test_bar(void* b);
++
++__attribute__((noinline))
++int test_foo(struct foo* a, void* b)
++{
++        a->x = 1;
++        test_bar(b);
++        return a->x;
++}
++
++int main()
++{
++        struct foo y;
++
++        if (2 != test_foo(&y, &y))
++                __builtin_abort();
++
++        return 0;
++}
++
++// TU2
++struct foo { int x; char a[0]; };
++
++void test_bar(void* b)
++{
++        struct foo *p = b;
++        p->x = 2;
++}
++
+diff --git a/gcc/testsuite/gcc.dg/pr117724.c b/gcc/testsuite/gcc.dg/pr117724.c
+new file mode 100644
+index 000000000000..d631daeb644d
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/pr117724.c
+@@ -0,0 +1,16 @@
++/* { dg-do compile } */
++/* { dg-options "-g" } */
++
++struct {
++  unsigned long len;
++  unsigned long size;
++  char data[];
++};			/* { dg-warning "unnamed struct" } */
++struct {
++  struct {
++    unsigned long len;
++    unsigned long size;
++    char data[6];
++  };
++};			/* { dg-warning "unnamed struct" } */
++
+diff --git a/gcc/tree.cc b/gcc/tree.cc
+index 1391af6bd4c3..9803d16805c4 100644
+--- a/gcc/tree.cc
++++ b/gcc/tree.cc
+@@ -13838,7 +13838,6 @@ type_with_interoperable_signedness (const_tree type)
+    that have TYPE_CANONICAL defined and assume them equivalent.  This is useful
+    only for LTO because only in these cases TYPE_CANONICAL equivalence
+    correspond to one defined by gimple_canonical_types_compatible_p.  */
+-
+ bool
+ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
+ 				     bool trust_type_canonical)
+@@ -13969,7 +13968,7 @@ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
+     {
+     case ARRAY_TYPE:
+       /* Array types are the same if the element types are the same and
+-	 the number of elements are the same.  */
++	 minimum and maximum index are the same.  */
+       if (!gimple_canonical_types_compatible_p (TREE_TYPE (t1), TREE_TYPE (t2),
+ 						trust_type_canonical)
+ 	  || TYPE_STRING_FLAG (t1) != TYPE_STRING_FLAG (t2)
+@@ -14063,23 +14062,46 @@ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
+ 	     f1 || f2;
+ 	     f1 = TREE_CHAIN (f1), f2 = TREE_CHAIN (f2))
+ 	  {
+-	    /* Skip non-fields and zero-sized fields.  */
++	    /* Skip non-fields and zero-sized fields, except zero-sized
++	       arrays at the end.  */
+ 	    while (f1 && (TREE_CODE (f1) != FIELD_DECL
+ 			  || (DECL_SIZE (f1)
+-			      && integer_zerop (DECL_SIZE (f1)))))
++			      && integer_zerop (DECL_SIZE (f1))
++			      && (TREE_CHAIN (f1)
++				  || TREE_CODE (TREE_TYPE (f1))
++				     != ARRAY_TYPE))))
+ 	      f1 = TREE_CHAIN (f1);
+ 	    while (f2 && (TREE_CODE (f2) != FIELD_DECL
+ 			  || (DECL_SIZE (f2)
+-			      && integer_zerop (DECL_SIZE (f2)))))
++			      && integer_zerop (DECL_SIZE (f2))
++			      && (TREE_CHAIN (f2)
++				  || TREE_CODE (TREE_TYPE (f2))
++				     != ARRAY_TYPE))))
+ 	      f2 = TREE_CHAIN (f2);
+ 	    if (!f1 || !f2)
+ 	      break;
+-	    /* The fields must have the same name, offset and type.  */
++
++	    tree t1 = TREE_TYPE (f1);
++	    tree t2 = TREE_TYPE (f2);
++
++	    /* If the last element are arrays, we only compare the element
++	       types.  */
++	    if (TREE_CHAIN (f1) == NULL_TREE && TREE_CODE (t1) == ARRAY_TYPE
++		&& TREE_CHAIN (f2) == NULL_TREE && TREE_CODE (t2) == ARRAY_TYPE)
++	      {
++		/* If both arrays have zero size, this is a match.  */
++		if (DECL_SIZE (f1) && integer_zerop (DECL_SIZE (f1))
++		    && DECL_SIZE (f2) && integer_zerop (DECL_SIZE (f2)))
++		  return true;
++
++		t1 = TREE_TYPE (t1);
++		t2 = TREE_TYPE (t2);
++	      }
++
+ 	    if (DECL_NONADDRESSABLE_P (f1) != DECL_NONADDRESSABLE_P (f2)
+ 		|| !gimple_compare_field_offset (f1, f2)
+ 		|| !gimple_canonical_types_compatible_p
+-		      (TREE_TYPE (f1), TREE_TYPE (f2),
+-		       trust_type_canonical))
++		      (t1, t2, trust_type_canonical))
+ 	      return false;
+ 	  }
+ 
+-- 
+2.47.1
+
diff --git a/15.0.0/gentoo/75_all_PR117724-testsuite-fix-LTO-flags-in-pr112716.c.patch b/15.0.0/gentoo/75_all_PR117724-testsuite-fix-LTO-flags-in-pr112716.c.patch
deleted file mode 100644
index f36840e..0000000
--- a/15.0.0/gentoo/75_all_PR117724-testsuite-fix-LTO-flags-in-pr112716.c.patch
+++ /dev/null
@@ -1,27 +0,0 @@
-From 2f961c392ab359286ef1350d37e50e7841773d7b Mon Sep 17 00:00:00 2001
-Message-ID: <2f961c392ab359286ef1350d37e50e7841773d7b.1733713329.git.sam@gentoo.org>
-In-Reply-To: <e1d3dfa0936ca5b50c87f6ddf5347fa401a703f6.1733713329.git.sam@gentoo.org>
-References: <e1d3dfa0936ca5b50c87f6ddf5347fa401a703f6.1733713329.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Mon, 9 Dec 2024 03:01:47 +0000
-Subject: [PATCH 2/2] testsuite: fix LTO flags in pr112716.c
-
----
- gcc/testsuite/gcc.dg/pr112716.c | 3 ++-
- 1 file changed, 2 insertions(+), 1 deletion(-)
-
-diff --git a/gcc/testsuite/gcc.dg/pr112716.c b/gcc/testsuite/gcc.dg/pr112716.c
-index 109dd252f0d6..873eedaafd18 100644
---- a/gcc/testsuite/gcc.dg/pr112716.c
-+++ b/gcc/testsuite/gcc.dg/pr112716.c
-@@ -1,5 +1,6 @@
- /* { dg-do compile } */
--/* { dg-options "-lfto -O2" } */
-+/* { dg-options "-flto -O2" } */
-+/* { dg-require-effective-target lto } */
- 
- #define T1 int[n]
- #define T2 int[n]
--- 
-2.47.1
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 639981b..50ec527 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -3,7 +3,7 @@
 	U 24_all_DEF_GENTOO_SCP-fstack-clash-protection.patch
 	U 26_all_enable-cet.patch
 	+ 74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
-	+ 75_all_PR117724-testsuite-fix-LTO-flags-in-pr112716.c.patch
+	+ 75_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array-2.patch
 	+ 76_all_PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch
 
 30	8 December 2024
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-10 19:19 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-10 19:19 UTC (permalink / raw
  To: gentoo-commits
commit:     da4a3098bbcf081bb00723bf7aacab98ff8e5a72
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 10 19:17:46 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Dec 10 19:17:46 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=da4a3098
15.0.0: cut patchset 10
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 50ec527..abc05c8 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-31	???
+31	10 December 2024
 
 	U 24_all_DEF_GENTOO_SCP-fstack-clash-protection.patch
 	U 26_all_enable-cet.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-11  0:58 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-11  0:58 UTC (permalink / raw
  To: gentoo-commits
commit:     51abf0facc39318f1b2e9f952ab7842ba422d401
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Dec 11 00:58:13 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Dec 11 00:58:13 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=51abf0fa
15.0.0: add 77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
Bug: https://gcc.gnu.org/PR117980
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ..._all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch | 13 +++++++++++++
 1 file changed, 13 insertions(+)
diff --git a/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch b/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
new file mode 100644
index 0000000..ba2fa9a
--- /dev/null
+++ b/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
@@ -0,0 +1,13 @@
+diff --git a/gcc/cp/cp-gimplify.cc b/gcc/cp/cp-gimplify.cc
+index 623e2ee6e964..a861331c7c7d 100644
+--- a/gcc/cp/cp-gimplify.cc
++++ b/gcc/cp/cp-gimplify.cc
+@@ -1477,7 +1477,7 @@ cp_fold_r (tree *stmt_p, int *walk_subtrees, void *data_)
+ 	  *walk_subtrees = 0;
+ 	  if (!flag_no_inline)
+ 	    {
+-	      tree folded = maybe_constant_init (init, TARGET_EXPR_SLOT (stmt));
++	      tree folded = maybe_constant_init (init);
+ 	      if (folded != init && TREE_CONSTANT (folded))
+ 		init = folded;
+ 	    }
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-11  4:41 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-11  4:41 UTC (permalink / raw
  To: gentoo-commits
commit:     bab06f8fff99acedad7703b604dd781a0f5554a0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Dec 11 04:41:01 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Dec 11 04:41:01 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=bab06f8f
15.0.0: add comment link to 77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch  | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch b/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
index ba2fa9a..1252fc2 100644
--- a/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
+++ b/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
@@ -1,5 +1,4 @@
-diff --git a/gcc/cp/cp-gimplify.cc b/gcc/cp/cp-gimplify.cc
-index 623e2ee6e964..a861331c7c7d 100644
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=117980#c7
 --- a/gcc/cp/cp-gimplify.cc
 +++ b/gcc/cp/cp-gimplify.cc
 @@ -1477,7 +1477,7 @@ cp_fold_r (tree *stmt_p, int *walk_subtrees, void *data_)
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-12 12:28 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-12 12:28 UTC (permalink / raw
  To: gentoo-commits
commit:     5dc272f0f180fae9fc937881a213cbe907e5a8f8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Dec 12 12:27:59 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Dec 12 12:28:21 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=5dc272f0
15.0.0: drop C23 FAM fixes
Now upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...mpatibility-for-types-with-flexible-array.patch |  80 -------
 ...atibility-for-types-with-flexible-array-2.patch | 250 ---------------------
 15.0.0/gentoo/README.history                       |   5 +
 3 files changed, 5 insertions(+), 330 deletions(-)
diff --git a/15.0.0/gentoo/74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch b/15.0.0/gentoo/74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
deleted file mode 100644
index 1b682ad..0000000
--- a/15.0.0/gentoo/74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
+++ /dev/null
@@ -1,80 +0,0 @@
-From 511aac7c85e6cc2ce474e1169dadd17c570743ec Mon Sep 17 00:00:00 2001
-Message-ID: <511aac7c85e6cc2ce474e1169dadd17c570743ec.1733842378.git.sam@gentoo.org>
-From: Martin Uecker <uecker@tugraz.at>
-Date: Tue, 10 Dec 2024 13:29:27 +0100
-Subject: [PATCH 1/2] Fix type compatibility for types with flexible array
- member [PR113688,PR114713,PR117724]
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-As requested, I split up into one part for the TYPE_MODE and 
-another one for the array size to help with git bisecting.  This
-is the first part.
-
-Bootstrapped and regression tested on x86_64.
-
-Allow the TYPE_MODE of a type with an array as last member to differ from
-another compatible type.
-
-gcc/ChangeLog:
-        * tree.cc (gimple_canonical_types_compatible_p): Add exception.
-        (verify_type): Add exception.
-
-gcc/lto/ChangeLog:
-        * lto-common.cc (hash_canonical_type): Add exception.
----
- gcc/lto/lto-common.cc |  3 ++-
- gcc/tree.cc           | 12 +++++++++---
- 2 files changed, 11 insertions(+), 4 deletions(-)
-
-diff --git a/gcc/lto/lto-common.cc b/gcc/lto/lto-common.cc
-index 86a309f92b40..940502099128 100644
---- a/gcc/lto/lto-common.cc
-+++ b/gcc/lto/lto-common.cc
-@@ -254,7 +254,8 @@ hash_canonical_type (tree type)
-      checked.  */
-   code = tree_code_for_canonical_type_merging (TREE_CODE (type));
-   hstate.add_int (code);
--  hstate.add_int (TYPE_MODE (type));
-+  if (!RECORD_OR_UNION_TYPE_P (type))
-+    hstate.add_int (TYPE_MODE (type));
- 
-   /* Incorporate common features of numerical types.  */
-   if (INTEGRAL_TYPE_P (type)
-diff --git a/gcc/tree.cc b/gcc/tree.cc
-index 83a03374a325..1391af6bd4c3 100644
---- a/gcc/tree.cc
-+++ b/gcc/tree.cc
-@@ -13914,8 +13914,11 @@ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
-       || TREE_CODE (t1) == NULLPTR_TYPE)
-     return true;
- 
--  /* Can't be the same type if they have different mode.  */
--  if (TYPE_MODE (t1) != TYPE_MODE (t2))
-+  /* Can't be compatible types if they have different mode.  Because of
-+     flexible array members, we allow mismatching modes for structures or
-+     unions.  */
-+  if (!RECORD_OR_UNION_TYPE_P (t1)
-+      && TYPE_MODE (t1) != TYPE_MODE (t2))
-     return false;
- 
-   /* Non-aggregate types can be handled cheaply.  */
-@@ -14218,8 +14221,11 @@ verify_type (const_tree t)
-       debug_tree (ct);
-       error_found = true;
-     }
--
-   if (COMPLETE_TYPE_P (t) && TYPE_CANONICAL (t)
-+      /* We allow a mismatch for structure or union because of
-+	 flexible array members.  */
-+      && !RECORD_OR_UNION_TYPE_P (t)
-+      && !RECORD_OR_UNION_TYPE_P (TYPE_CANONICAL (t))
-       && TYPE_MODE (t) != TYPE_MODE (TYPE_CANONICAL (t)))
-     {
-       error ("%<TYPE_MODE%> of %<TYPE_CANONICAL%> is not compatible");
-
-base-commit: 34dfb30ca8dba6bc184e563b0ddc26a5239294e3
--- 
-2.47.1
-
diff --git a/15.0.0/gentoo/75_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array-2.patch b/15.0.0/gentoo/75_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array-2.patch
deleted file mode 100644
index 1f35b83..0000000
--- a/15.0.0/gentoo/75_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array-2.patch
+++ /dev/null
@@ -1,250 +0,0 @@
-From 4bc7c98e86392a36f75029eabbe096d1bf9e85b5 Mon Sep 17 00:00:00 2001
-Message-ID: <4bc7c98e86392a36f75029eabbe096d1bf9e85b5.1733842378.git.sam@gentoo.org>
-In-Reply-To: <511aac7c85e6cc2ce474e1169dadd17c570743ec.1733842378.git.sam@gentoo.org>
-References: <511aac7c85e6cc2ce474e1169dadd17c570743ec.1733842378.git.sam@gentoo.org>
-From: Martin Uecker <uecker@tugraz.at>
-Date: Tue, 10 Dec 2024 13:31:50 +0100
-Subject: [PATCH 2/2] Fix type compatibility for types with flexible array
- member [PR113688,PR114713,PR117724]
-
-The second part now only contains the changes for array size.
-
-I added back a special case for this instead of having the
-'ignore_size' flag (which I would nevertheless assume might be
-needed in the future when matching pointer types).
-
-In this version, I added an exception to the special case to ignore
-the case were both are zero-sized arrays, because this seems to be
-the only case were the new code would otherwise be stricter than the
-old code.
-
-I also replaced/fixed one test where I accidentally included a similar
-test for another closely related bug involving VLA types.
-
-Bootstrapped and regression tested on x86_64.
-
-For checking or computing TYPE_CANONICAL, ignore the array size when it is
-the last element of a structure or union.  To not get errors because of
-an inconsistent number of members, zero-sized arrays which are the last
-element are not ignored anymore when checking the fields of a struct.
-
-	PR c/113688
-	PR c/114014
-	PR c/114713
-	PR c/117724
-
-gcc/ChangeLog:
-	* tree.cc (gimple_canonical_types_compatible_p): Add exception.
-
-gcc/lto/ChangeLog:
-	* lto-common.cc (hash_canonical_type): Add exception.
-
-gcc/testsuite/ChangeLog:
-	* gcc.dg/pr113688.c: New test.
-	* gcc.dg/pr114014.c: New test.
-	* gcc.dg/pr114713.c: New test.
-	* gcc.dg/pr117724.c: New test.
----
- gcc/lto/lto-common.cc           |  6 +++++-
- gcc/testsuite/gcc.dg/pr113688.c |  8 +++++++
- gcc/testsuite/gcc.dg/pr114014.c | 14 ++++++++++++
- gcc/testsuite/gcc.dg/pr114713.c | 35 ++++++++++++++++++++++++++++++
- gcc/testsuite/gcc.dg/pr117724.c | 16 ++++++++++++++
- gcc/tree.cc                     | 38 ++++++++++++++++++++++++++-------
- 6 files changed, 108 insertions(+), 9 deletions(-)
- create mode 100644 gcc/testsuite/gcc.dg/pr113688.c
- create mode 100644 gcc/testsuite/gcc.dg/pr114014.c
- create mode 100644 gcc/testsuite/gcc.dg/pr114713.c
- create mode 100644 gcc/testsuite/gcc.dg/pr117724.c
-
-diff --git a/gcc/lto/lto-common.cc b/gcc/lto/lto-common.cc
-index 940502099128..f65a9d1c7b6f 100644
---- a/gcc/lto/lto-common.cc
-+++ b/gcc/lto/lto-common.cc
-@@ -333,7 +333,11 @@ hash_canonical_type (tree type)
- 	    && (! DECL_SIZE (f)
- 		|| ! integer_zerop (DECL_SIZE (f))))
- 	  {
--	    iterative_hash_canonical_type (TREE_TYPE (f), hstate);
-+	    tree t = TREE_TYPE (f);
-+	    if (!TREE_CHAIN (f)
-+		&& TREE_CODE (t) == ARRAY_TYPE)
-+	      t = TREE_TYPE  (t);
-+	    iterative_hash_canonical_type (t, hstate);
- 	    nf++;
- 	  }
- 
-diff --git a/gcc/testsuite/gcc.dg/pr113688.c b/gcc/testsuite/gcc.dg/pr113688.c
-new file mode 100644
-index 000000000000..8dee8c86f1bf
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/pr113688.c
-@@ -0,0 +1,8 @@
-+/* { dg-do compile } */
-+/* { dg-options "-g" } */
-+
-+struct S{int x,y[1];}*a;
-+int main(void){
-+	struct S{int x,y[];};
-+}
-+
-diff --git a/gcc/testsuite/gcc.dg/pr114014.c b/gcc/testsuite/gcc.dg/pr114014.c
-new file mode 100644
-index 000000000000..1531ffab1b75
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/pr114014.c
-@@ -0,0 +1,14 @@
-+/* PR c/114014
-+ * { dg-do compile }
-+ * { dg-options "-std=gnu23 -g" } */
-+
-+struct r {
-+  int a;
-+  char b[];
-+};
-+struct r {
-+  int a;
-+  char b[0];
-+};
-+
-+
-diff --git a/gcc/testsuite/gcc.dg/pr114713.c b/gcc/testsuite/gcc.dg/pr114713.c
-new file mode 100644
-index 000000000000..1f0ad39c433c
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/pr114713.c
-@@ -0,0 +1,35 @@
-+/* { dg-do run } */
-+/* { dg-require-effective-target lto } */
-+/* { dg-options "-flto -O2" } */
-+
-+struct foo { int x; char a[]; };
-+
-+void test_bar(void* b);
-+
-+__attribute__((noinline))
-+int test_foo(struct foo* a, void* b)
-+{
-+        a->x = 1;
-+        test_bar(b);
-+        return a->x;
-+}
-+
-+int main()
-+{
-+        struct foo y;
-+
-+        if (2 != test_foo(&y, &y))
-+                __builtin_abort();
-+
-+        return 0;
-+}
-+
-+// TU2
-+struct foo { int x; char a[0]; };
-+
-+void test_bar(void* b)
-+{
-+        struct foo *p = b;
-+        p->x = 2;
-+}
-+
-diff --git a/gcc/testsuite/gcc.dg/pr117724.c b/gcc/testsuite/gcc.dg/pr117724.c
-new file mode 100644
-index 000000000000..d631daeb644d
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/pr117724.c
-@@ -0,0 +1,16 @@
-+/* { dg-do compile } */
-+/* { dg-options "-g" } */
-+
-+struct {
-+  unsigned long len;
-+  unsigned long size;
-+  char data[];
-+};			/* { dg-warning "unnamed struct" } */
-+struct {
-+  struct {
-+    unsigned long len;
-+    unsigned long size;
-+    char data[6];
-+  };
-+};			/* { dg-warning "unnamed struct" } */
-+
-diff --git a/gcc/tree.cc b/gcc/tree.cc
-index 1391af6bd4c3..9803d16805c4 100644
---- a/gcc/tree.cc
-+++ b/gcc/tree.cc
-@@ -13838,7 +13838,6 @@ type_with_interoperable_signedness (const_tree type)
-    that have TYPE_CANONICAL defined and assume them equivalent.  This is useful
-    only for LTO because only in these cases TYPE_CANONICAL equivalence
-    correspond to one defined by gimple_canonical_types_compatible_p.  */
--
- bool
- gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
- 				     bool trust_type_canonical)
-@@ -13969,7 +13968,7 @@ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
-     {
-     case ARRAY_TYPE:
-       /* Array types are the same if the element types are the same and
--	 the number of elements are the same.  */
-+	 minimum and maximum index are the same.  */
-       if (!gimple_canonical_types_compatible_p (TREE_TYPE (t1), TREE_TYPE (t2),
- 						trust_type_canonical)
- 	  || TYPE_STRING_FLAG (t1) != TYPE_STRING_FLAG (t2)
-@@ -14063,23 +14062,46 @@ gimple_canonical_types_compatible_p (const_tree t1, const_tree t2,
- 	     f1 || f2;
- 	     f1 = TREE_CHAIN (f1), f2 = TREE_CHAIN (f2))
- 	  {
--	    /* Skip non-fields and zero-sized fields.  */
-+	    /* Skip non-fields and zero-sized fields, except zero-sized
-+	       arrays at the end.  */
- 	    while (f1 && (TREE_CODE (f1) != FIELD_DECL
- 			  || (DECL_SIZE (f1)
--			      && integer_zerop (DECL_SIZE (f1)))))
-+			      && integer_zerop (DECL_SIZE (f1))
-+			      && (TREE_CHAIN (f1)
-+				  || TREE_CODE (TREE_TYPE (f1))
-+				     != ARRAY_TYPE))))
- 	      f1 = TREE_CHAIN (f1);
- 	    while (f2 && (TREE_CODE (f2) != FIELD_DECL
- 			  || (DECL_SIZE (f2)
--			      && integer_zerop (DECL_SIZE (f2)))))
-+			      && integer_zerop (DECL_SIZE (f2))
-+			      && (TREE_CHAIN (f2)
-+				  || TREE_CODE (TREE_TYPE (f2))
-+				     != ARRAY_TYPE))))
- 	      f2 = TREE_CHAIN (f2);
- 	    if (!f1 || !f2)
- 	      break;
--	    /* The fields must have the same name, offset and type.  */
-+
-+	    tree t1 = TREE_TYPE (f1);
-+	    tree t2 = TREE_TYPE (f2);
-+
-+	    /* If the last element are arrays, we only compare the element
-+	       types.  */
-+	    if (TREE_CHAIN (f1) == NULL_TREE && TREE_CODE (t1) == ARRAY_TYPE
-+		&& TREE_CHAIN (f2) == NULL_TREE && TREE_CODE (t2) == ARRAY_TYPE)
-+	      {
-+		/* If both arrays have zero size, this is a match.  */
-+		if (DECL_SIZE (f1) && integer_zerop (DECL_SIZE (f1))
-+		    && DECL_SIZE (f2) && integer_zerop (DECL_SIZE (f2)))
-+		  return true;
-+
-+		t1 = TREE_TYPE (t1);
-+		t2 = TREE_TYPE (t2);
-+	      }
-+
- 	    if (DECL_NONADDRESSABLE_P (f1) != DECL_NONADDRESSABLE_P (f2)
- 		|| !gimple_compare_field_offset (f1, f2)
- 		|| !gimple_canonical_types_compatible_p
--		      (TREE_TYPE (f1), TREE_TYPE (f2),
--		       trust_type_canonical))
-+		      (t1, t2, trust_type_canonical))
- 	      return false;
- 	  }
- 
--- 
-2.47.1
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index abc05c8..8b73c10 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,8 @@
+32	????
+
+	- 74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
+	- 75_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array-2.patch
+
 31	10 December 2024
 
 	U 24_all_DEF_GENTOO_SCP-fstack-clash-protection.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-13  5:08 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-13  5:08 UTC (permalink / raw
  To: gentoo-commits
commit:     9af17f2c6db4433f71d81aed95fca9a95780bb25
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 13 05:08:30 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Dec 13 05:08:30 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=9af17f2c
15.0.0: update C++ ICE patch
The actual fix is the same but it adds testcases and a commit message, so
let's sync up.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...7980-ICE-cxx_eval_outermost_constant_expr.patch | 120 ++++++++++++++++++++-
 1 file changed, 119 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch b/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
index 1252fc2..f077536 100644
--- a/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
+++ b/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
@@ -1,4 +1,64 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=117980#c7
+https://inbox.sourceware.org/gcc-patches/20241212184222.471783-1-polacek@redhat.com/
+
+From f9ec39fcb8905fad2aba87bf328f0d5934b2385d Mon Sep 17 00:00:00 2001
+Message-ID: <f9ec39fcb8905fad2aba87bf328f0d5934b2385d.1734066473.git.sam@gentoo.org>
+From: Marek Polacek <polacek@redhat.com>
+Date: Thu, 12 Dec 2024 13:42:22 -0500
+Subject: [PATCH] c++: ICE in TARGET_EXPR evaluation in cp_fold_r [PR117980]
+
+This ICE started with the recent prvalue optimization (r15-6052).  In
+cp_fold_r we have:
+
+      if (tree &init = TARGET_EXPR_INITIAL (stmt))
+        {
+          cp_walk_tree (&init, cp_fold_r, data, NULL);
+          // ...
+	  tree folded = maybe_constant_init (init, TARGET_EXPR_SLOT (stmt));
+
+What can happen here is that originally the TARGET_EXPR is:
+
+    TARGET_EXPR <D.2747, <<< Unknown tree: aggr_init_expr
+      5
+      __ct_comp
+      D.2747
+      (struct subrange *) <<< Unknown tree: void_cst >>>
+      &TARGET_EXPR <D.2707, {.it=TARGET_EXPR <D.2695, ...>}> >>>>
+
+but after the first cp_walk_tree we fold the D.2707 TARGET_EXPR into:
+
+    TARGET_EXPR <D.2707, <<< Unknown tree: expr_stmt
+      D.2707.it = TARGET_EXPR <D.2695, ...> >>>>
+
+and then we pass the EXPR_STMT to maybe_constant_init, with D.2707 as
+the object.  But their types don't match anymore, so we crash.  We'd
+have to pass D.2707.it as the object for it to work.
+
+But I don't think we need to pass any object to maybe_constant_init;
+it'll grab the appropriate one itself.
+
+constexpr-prvalue3.C is reduced from a large std::ranges libstdc++ test.
+
+	PR c++/117980
+
+gcc/cp/ChangeLog:
+
+	* cp-gimplify.cc (cp_fold_r) <case TARGET_EXPR>: Don't pass an object
+	to maybe_constant_init.
+
+gcc/testsuite/ChangeLog:
+
+* g++.dg/cpp0x/constexpr-prvalue2.C: New test.
+	* g++.dg/cpp0x/constexpr-prvalue3.C: New test.
+---
+ gcc/cp/cp-gimplify.cc                         |  2 +-
+ .../g++.dg/cpp0x/constexpr-prvalue2.C         | 15 +++++++++++
+ .../g++.dg/cpp0x/constexpr-prvalue3.C         | 26 +++++++++++++++++++
+ 3 files changed, 42 insertions(+), 1 deletion(-)
+ create mode 100644 gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue2.C
+ create mode 100644 gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue3.C
+
+diff --git a/gcc/cp/cp-gimplify.cc b/gcc/cp/cp-gimplify.cc
+index 623e2ee6e964..a861331c7c7d 100644
 --- a/gcc/cp/cp-gimplify.cc
 +++ b/gcc/cp/cp-gimplify.cc
 @@ -1477,7 +1477,7 @@ cp_fold_r (tree *stmt_p, int *walk_subtrees, void *data_)
@@ -10,3 +70,61 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=117980#c7
  	      if (folded != init && TREE_CONSTANT (folded))
  		init = folded;
  	    }
+diff --git a/gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue2.C b/gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue2.C
+new file mode 100644
+index 000000000000..46053231cf83
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue2.C
+@@ -0,0 +1,15 @@
++// PR c++/117980
++// { dg-do compile { target c++11 } }
++// { dg-options "-O" }
++
++struct S {
++  constexpr S(S &); // { dg-warning "used but never defined" }
++  ~S();
++};
++struct B {
++  S s;
++};
++struct A {
++  B b;
++};
++void fn(B b) { A{b}; }
+diff --git a/gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue3.C b/gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue3.C
+new file mode 100644
+index 000000000000..a2eb12c02d74
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue3.C
+@@ -0,0 +1,26 @@
++// PR c++/117980
++// { dg-do compile { target c++11 } }
++// { dg-options "-O" }
++
++struct _Safe_iterator  {
++ _Safe_iterator();
++  ~_Safe_iterator();
++};
++template <typename _Tp>
++struct vector {
++  vector(int) {}
++  constexpr _Safe_iterator end() {
++    return _Safe_iterator();
++  }
++};
++template <typename It> struct sentinel {
++  It it;
++};
++template <typename _Sent>
++struct subrange {
++  subrange(sentinel<_Safe_iterator>) {}
++};
++void test01() {
++  vector<int> v{0};
++  subrange<sentinel<_Safe_iterator>>{sentinel<_Safe_iterator>{v.end()}};
++}
+
+base-commit: d136fa00f0d5faff8397edcd7e4ebb3445ab21b0
+-- 
+2.47.1
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-13 11:52 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-13 11:52 UTC (permalink / raw
  To: gentoo-commits
commit:     43890f63608afe071e8a5d5c5d3237956a527ea8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 13 11:51:58 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Dec 13 11:51:58 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=43890f63
15.0.0: update 72_all_PR111600-genrecog-Split-into-separate-partitions.patch
Includes configure regen.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...0-genrecog-Split-into-separate-partitions.patch | 47 ++++++++++++++++------
 1 file changed, 35 insertions(+), 12 deletions(-)
diff --git a/15.0.0/gentoo/72_all_PR111600-genrecog-Split-into-separate-partitions.patch b/15.0.0/gentoo/72_all_PR111600-genrecog-Split-into-separate-partitions.patch
index 07486e4..ae2b837 100644
--- a/15.0.0/gentoo/72_all_PR111600-genrecog-Split-into-separate-partitions.patch
+++ b/15.0.0/gentoo/72_all_PR111600-genrecog-Split-into-separate-partitions.patch
@@ -1,5 +1,5 @@
-From 1135970eb38c8f90db20c12cb4222e3a5214557e Mon Sep 17 00:00:00 2001
-Message-ID: <1135970eb38c8f90db20c12cb4222e3a5214557e.1732630692.git.sam@gentoo.org>
+From eea603288d8d6cfd795c42c8f731d06f8af6828a Mon Sep 17 00:00:00 2001
+Message-ID: <eea603288d8d6cfd795c42c8f731d06f8af6828a.1734090687.git.sam@gentoo.org>
 From: Robin Dapp <rdapp.gcc@gmail.com>
 Date: Tue, 26 Nov 2024 14:44:17 +0100
 Subject: [PATCH] genrecog: Split into separate partitions [PR111600].
@@ -55,6 +55,7 @@ gcc/ChangeLog:
 	* read-md.h (class md_reader): Ditto.
 ---
  gcc/Makefile.in      |  29 ++-
+ gcc/configure        |   4 +-
  gcc/configure.ac     |   4 +-
  gcc/genconditions.cc |   4 +-
  gcc/genpreds.cc      |   4 +-
@@ -62,10 +63,10 @@ gcc/ChangeLog:
  gcc/gentarget-def.cc |   2 +-
  gcc/read-md.cc       |   4 +-
  gcc/read-md.h        |   2 +-
- 8 files changed, 358 insertions(+), 243 deletions(-)
+ 9 files changed, 360 insertions(+), 245 deletions(-)
 
 diff --git a/gcc/Makefile.in b/gcc/Makefile.in
-index ead8d2eb094c..d301bef47003 100644
+index 27fbbd4bf19e..493ec6a5cb6e 100644
 --- a/gcc/Makefile.in
 +++ b/gcc/Makefile.in
 @@ -239,6 +239,12 @@ INSNEMIT_SEQ_SRC = $(patsubst %, insn-emit-%.cc, $(INSNEMIT_SPLITS_SEQ))
@@ -90,7 +91,7 @@ index ead8d2eb094c..d301bef47003 100644
  	insn-enums.o \
  	ggc-page.o \
  	adjust-alignment.o \
-@@ -1903,8 +1909,8 @@ TREECHECKING = @TREECHECKING@
+@@ -1909,8 +1915,8 @@ TREECHECKING = @TREECHECKING@
  FULL_DRIVER_NAME=$(target_noncanonical)-gcc-$(version)$(exeext)
  
  MOSTLYCLEANFILES = insn-flags.h insn-config.h insn-codes.h \
@@ -101,7 +102,7 @@ index ead8d2eb094c..d301bef47003 100644
   insn-attr.h insn-attr-common.h insn-attrtab.cc insn-dfatab.cc \
   insn-latencytab.cc insn-opinit.cc insn-opinit.h insn-preds.cc insn-constants.h \
   tm-preds.h tm-constrs.h checksum-options $(GIMPLE_MATCH_PD_SEQ_SRC) \
-@@ -2671,7 +2677,8 @@ $(common_out_object_file): $(common_out_file)
+@@ -2677,7 +2683,8 @@ $(common_out_object_file): $(common_out_file)
  # and compile them.
  
  .PRECIOUS: insn-config.h insn-flags.h insn-codes.h insn-constants.h \
@@ -111,7 +112,7 @@ index ead8d2eb094c..d301bef47003 100644
    insn-peep.cc insn-attr.h insn-attr-common.h insn-attrtab.cc \
    insn-dfatab.cc insn-latencytab.cc insn-preds.cc \
    $(GIMPLE_MATCH_PD_SEQ_SRC) $(GENERIC_MATCH_PD_SEQ_SRC) \
-@@ -2700,7 +2707,7 @@ simple_rtl_generated_h	= insn-attr.h insn-attr-common.h insn-codes.h \
+@@ -2706,7 +2713,7 @@ simple_rtl_generated_h	= insn-attr.h insn-attr-common.h insn-codes.h \
  
  simple_rtl_generated_c	= insn-automata.cc \
  			  insn-extract.cc insn-output.cc \
@@ -120,7 +121,7 @@ index ead8d2eb094c..d301bef47003 100644
  
  simple_generated_h	= $(simple_rtl_generated_h) insn-constants.h
  
-@@ -2738,6 +2745,18 @@ s-tmp-emit: build/genemit$(build_exeext) $(MD_DEPS) insn-conditions.md
+@@ -2744,6 +2751,18 @@ s-tmp-emit: build/genemit$(build_exeext) $(MD_DEPS) insn-conditions.md
  	  insn-emit-$(id).cc;)
  	$(STAMP) s-tmp-emit
  
@@ -139,11 +140,33 @@ index ead8d2eb094c..d301bef47003 100644
  # gencheck doesn't read the machine description, and the file produced
  # doesn't use the insn-* convention.
  
+diff --git a/gcc/configure b/gcc/configure
+index 0a55fa75573b..a8b531d8fae0 100755
+--- a/gcc/configure
++++ b/gcc/configure
+@@ -1873,7 +1873,7 @@ Optional Packages:
+                           generic when splitting match.pd. [default=10]
+   --with-insnemit-partitions=num
+                           Set the number of partitions of insn-emit.cc for
+-                          genemit to create. [default=10]
++                          genemit and genrecog to create. [default=10]
+   --with-dwarf2           force the default debug format to be DWARF 2 (or
+                           later)
+   --with-specs=SPECS      add SPECS to driver command-line processing
+@@ -7936,7 +7936,7 @@ fi
+ 
+ 
+ 
+-# Specify the number of splits of insn-emit.cc to generate.
++# Specify the number of splits of insn-emit.cc and insn-recog.cc to generate.
+ 
+ # Check whether --with-insnemit-partitions was given.
+ if test "${with_insnemit_partitions+set}" = set; then :
 diff --git a/gcc/configure.ac b/gcc/configure.ac
-index c546432b2775..a0d9038ea595 100644
+index 1a6f01e25675..77fab885a428 100644
 --- a/gcc/configure.ac
 +++ b/gcc/configure.ac
-@@ -913,10 +913,10 @@ fi
+@@ -929,10 +929,10 @@ fi
  
  AC_SUBST(DEFAULT_MATCHPD_PARTITIONS)
  
@@ -195,7 +218,7 @@ index 55d149e8a404..b8f3bf279d97 100644
  		  "        SET_HARD_REG_BIT (%s[%d], regno);\n",
  		  "this_target_constraints->register_filters", i);
 diff --git a/gcc/genrecog.cc b/gcc/genrecog.cc
-index ba09ec3b6005..7f7ca728bbe0 100644
+index 719b1d44387e..1852ceba2513 100644
 --- a/gcc/genrecog.cc
 +++ b/gcc/genrecog.cc
 @@ -4255,9 +4255,9 @@ match_pattern (state *s, md_rtx_info *info, rtx pattern,
@@ -1363,7 +1386,7 @@ index e613c42b7241..b42add391ed8 100644
    /* Defined in read-rtl.cc.  */
    const char *apply_iterator_to_string (const char *string);
 
-base-commit: a22dfe208d94105a6e587a3b25e8fe8d62444d8a
+base-commit: 6a5a1b8175e07ff578204476cd11115d8a071cbc
 -- 
 2.47.1
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-13 13:23 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-13 13:23 UTC (permalink / raw
  To: gentoo-commits
commit:     d868db5ada6f12bebdcbf4a9ec1d0814c1cbafd8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 13 13:23:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Dec 13 13:23:15 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=d868db5a
15.0.0: drop 72_all_PR111600-genrecog-Split-into-separate-partitions.patch
Now upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...0-genrecog-Split-into-separate-partitions.patch | 1392 --------------------
 15.0.0/gentoo/README.history                       |    1 +
 2 files changed, 1 insertion(+), 1392 deletions(-)
diff --git a/15.0.0/gentoo/72_all_PR111600-genrecog-Split-into-separate-partitions.patch b/15.0.0/gentoo/72_all_PR111600-genrecog-Split-into-separate-partitions.patch
deleted file mode 100644
index ae2b837..0000000
--- a/15.0.0/gentoo/72_all_PR111600-genrecog-Split-into-separate-partitions.patch
+++ /dev/null
@@ -1,1392 +0,0 @@
-From eea603288d8d6cfd795c42c8f731d06f8af6828a Mon Sep 17 00:00:00 2001
-Message-ID: <eea603288d8d6cfd795c42c8f731d06f8af6828a.1734090687.git.sam@gentoo.org>
-From: Robin Dapp <rdapp.gcc@gmail.com>
-Date: Tue, 26 Nov 2024 14:44:17 +0100
-Subject: [PATCH] genrecog: Split into separate partitions [PR111600].
-
-Hi,
-
-this patch makes genrecog split its output into separate files (10 by
-default) in the same vein genemit does.  The changes are mostly
-mechanical again, changing printfs and puts to fprintf.
-As insn-recog.cc relies on being able to call other recog functions a
-header insn-recog.h is introduced that pre declares all of those.
-
-For simplicity the number of files is determined by (re-using)
---with-insnemit-partitions.  Naming suggestions welcome :)
-
-Bootstrapped and regtested on x86 and power10, regtested on riscv.
-aarch64 bootstrap is currently blocked because of the
-"maybe uninitialized" issue discussed on IRC.
-
-Regards
- Robin
-
-gcc/ChangeLog:
-
-* Makefile.in:  Add insn-recog split.
-	* configure.ac: Document that the number of insnemit partitions is
-	used for insn-recog as well.
-	* genconditions.cc (write_one_condition): Use fprintf.
-	* genpreds.cc (write_predicate_expr): Ditto.
-	(write_init_reg_class_start_regs): Ditto.
-	* genrecog.cc (write_header): Add header file to includes.
-	(printf_indent): Use fprintf.
-	(change_state): Ditto.
-	(print_code): Ditto.
-	(print_host_wide_int): Ditto.
-	(print_parameter_value): Ditto.
-	(print_test_rtx): Ditto.
-	(print_nonbool_test): Ditto.
-	(print_label_value): Ditto.
-	(print_test): Ditto.
-	(print_decision): Ditto.
-	(print_state): Ditto.
-	(print_subroutine_call): Ditto.
-	(print_acceptance): Ditto.
-	(print_subroutine_start): Ditto.
-	(print_pattern): Ditto.
-	(print_subroutine): Ditto.
-	(print_subroutine_group): Ditto.
-	(handle_arg): Add -O and -H for output and header file handling.
-	(main): Use callback.
-	* gentarget-def.cc (def_target_insn): Use fprintf.
-	* read-md.cc (md_reader::print_c_condition): Ditto.
-	* read-md.h (class md_reader): Ditto.
----
- gcc/Makefile.in      |  29 ++-
- gcc/configure        |   4 +-
- gcc/configure.ac     |   4 +-
- gcc/genconditions.cc |   4 +-
- gcc/genpreds.cc      |   4 +-
- gcc/genrecog.cc      | 552 +++++++++++++++++++++++++------------------
- gcc/gentarget-def.cc |   2 +-
- gcc/read-md.cc       |   4 +-
- gcc/read-md.h        |   2 +-
- 9 files changed, 360 insertions(+), 245 deletions(-)
-
-diff --git a/gcc/Makefile.in b/gcc/Makefile.in
-index 27fbbd4bf19e..493ec6a5cb6e 100644
---- a/gcc/Makefile.in
-+++ b/gcc/Makefile.in
-@@ -239,6 +239,12 @@ INSNEMIT_SEQ_SRC = $(patsubst %, insn-emit-%.cc, $(INSNEMIT_SPLITS_SEQ))
- INSNEMIT_SEQ_TMP = $(patsubst %, tmp-emit-%.cc, $(INSNEMIT_SPLITS_SEQ))
- INSNEMIT_SEQ_O = $(patsubst %, insn-emit-%.o, $(INSNEMIT_SPLITS_SEQ))
- 
-+# Re-use the split number for insn-recog as well.
-+INSNRECOG_SPLITS_SEQ = $(wordlist 1,$(NUM_INSNEMIT_SPLITS),$(one_to_9999))
-+INSNRECOG_SEQ_SRC = $(patsubst %, insn-recog-%.cc, $(INSNRECOG_SPLITS_SEQ))
-+INSNRECOG_SEQ_TMP = $(patsubst %, tmp-recog-%.cc, $(INSNRECOG_SPLITS_SEQ))
-+INSNRECOG_SEQ_O = $(patsubst %, insn-recog-%.o, $(INSNRECOG_SPLITS_SEQ))
-+
- # These files are to have specific diagnostics suppressed, or are not to
- # be subject to -Werror:
- # flex output may yield harmless "no previous prototype" warnings
-@@ -1385,7 +1391,7 @@ OBJS = \
- 	insn-output.o \
- 	insn-peep.o \
- 	insn-preds.o \
--	insn-recog.o \
-+	$(INSNRECOG_SEQ_O) \
- 	insn-enums.o \
- 	ggc-page.o \
- 	adjust-alignment.o \
-@@ -1909,8 +1915,8 @@ TREECHECKING = @TREECHECKING@
- FULL_DRIVER_NAME=$(target_noncanonical)-gcc-$(version)$(exeext)
- 
- MOSTLYCLEANFILES = insn-flags.h insn-config.h insn-codes.h \
-- insn-output.cc insn-recog.cc $(INSNEMIT_SEQ_SRC) \
-- insn-extract.cc insn-peep.cc \
-+ insn-output.cc $(INSNRECOG_SEQ_SRC) insn-recog.h \
-+ $(INSNEMIT_SEQ_SRC) insn-extract.cc insn-peep.cc \
-  insn-attr.h insn-attr-common.h insn-attrtab.cc insn-dfatab.cc \
-  insn-latencytab.cc insn-opinit.cc insn-opinit.h insn-preds.cc insn-constants.h \
-  tm-preds.h tm-constrs.h checksum-options $(GIMPLE_MATCH_PD_SEQ_SRC) \
-@@ -2677,7 +2683,8 @@ $(common_out_object_file): $(common_out_file)
- # and compile them.
- 
- .PRECIOUS: insn-config.h insn-flags.h insn-codes.h insn-constants.h \
--  $(INSNEMIT_SEQ_SRC) insn-recog.cc insn-extract.cc insn-output.cc \
-+  $(INSNEMIT_SEQ_SRC) insn-recog.h $(INSNRECOG_SEQ_SRC) \
-+  insn-extract.cc insn-output.cc \
-   insn-peep.cc insn-attr.h insn-attr-common.h insn-attrtab.cc \
-   insn-dfatab.cc insn-latencytab.cc insn-preds.cc \
-   $(GIMPLE_MATCH_PD_SEQ_SRC) $(GENERIC_MATCH_PD_SEQ_SRC) \
-@@ -2706,7 +2713,7 @@ simple_rtl_generated_h	= insn-attr.h insn-attr-common.h insn-codes.h \
- 
- simple_rtl_generated_c	= insn-automata.cc \
- 			  insn-extract.cc insn-output.cc \
--			  insn-peep.cc insn-recog.cc
-+			  insn-peep.cc
- 
- simple_generated_h	= $(simple_rtl_generated_h) insn-constants.h
- 
-@@ -2744,6 +2751,18 @@ s-tmp-emit: build/genemit$(build_exeext) $(MD_DEPS) insn-conditions.md
- 	  insn-emit-$(id).cc;)
- 	$(STAMP) s-tmp-emit
- 
-+# Same for genrecog.
-+$(INSNRECOG_SEQ_SRC): s-tmp-recog; @true
-+insn-recog.h: s-tmp-recog; @true
-+s-tmp-recog: build/genrecog$(build_exeext) $(MD_DEPS) insn-conditions.md
-+	$(RUN_GEN) build/genrecog$(build_exeext) $(md_file) insn-conditions.md \
-+	  -Hinsn-recog.h \
-+	  $(addprefix -O,${INSNRECOG_SEQ_TMP})
-+	$(foreach id, $(INSNRECOG_SPLITS_SEQ), \
-+	  $(SHELL) $(srcdir)/../move-if-change tmp-recog-$(id).cc \
-+	  insn-recog-$(id).cc;)
-+	$(STAMP) s-tmp-recog
-+
- # gencheck doesn't read the machine description, and the file produced
- # doesn't use the insn-* convention.
- 
-diff --git a/gcc/configure b/gcc/configure
-index 0a55fa75573b..a8b531d8fae0 100755
---- a/gcc/configure
-+++ b/gcc/configure
-@@ -1873,7 +1873,7 @@ Optional Packages:
-                           generic when splitting match.pd. [default=10]
-   --with-insnemit-partitions=num
-                           Set the number of partitions of insn-emit.cc for
--                          genemit to create. [default=10]
-+                          genemit and genrecog to create. [default=10]
-   --with-dwarf2           force the default debug format to be DWARF 2 (or
-                           later)
-   --with-specs=SPECS      add SPECS to driver command-line processing
-@@ -7936,7 +7936,7 @@ fi
- 
- 
- 
--# Specify the number of splits of insn-emit.cc to generate.
-+# Specify the number of splits of insn-emit.cc and insn-recog.cc to generate.
- 
- # Check whether --with-insnemit-partitions was given.
- if test "${with_insnemit_partitions+set}" = set; then :
-diff --git a/gcc/configure.ac b/gcc/configure.ac
-index 1a6f01e25675..77fab885a428 100644
---- a/gcc/configure.ac
-+++ b/gcc/configure.ac
-@@ -929,10 +929,10 @@ fi
- 
- AC_SUBST(DEFAULT_MATCHPD_PARTITIONS)
- 
--# Specify the number of splits of insn-emit.cc to generate.
-+# Specify the number of splits of insn-emit.cc and insn-recog.cc to generate.
- AC_ARG_WITH(insnemit-partitions,
- [AS_HELP_STRING([--with-insnemit-partitions=num],
--[Set the number of partitions of insn-emit.cc for genemit to create. [default=10]])],
-+[Set the number of partitions of insn-emit.cc for genemit and genrecog to create. [default=10]])],
- [DEFAULT_INSNEMIT_PARTITIONS="$with_insnemit_partitions"], [DEFAULT_INSNEMIT_PARTITIONS=10])
- if (test $DEFAULT_INSNEMIT_PARTITIONS -lt 1); then
-   AC_MSG_ERROR(m4_normalize([
-diff --git a/gcc/genconditions.cc b/gcc/genconditions.cc
-index 13963dc3ff46..9da460893d52 100644
---- a/gcc/genconditions.cc
-+++ b/gcc/genconditions.cc
-@@ -141,9 +141,9 @@ write_one_condition (void **slot, void * ARG_UNUSED (dummy))
-     }
- 
-   fputs ("\",\n    __builtin_constant_p ", stdout);
--  rtx_reader_ptr->print_c_condition (test->expr);
-+  rtx_reader_ptr->print_c_condition (stdout, test->expr);
-   fputs ("\n    ? (int) ", stdout);
--  rtx_reader_ptr->print_c_condition (test->expr);
-+  rtx_reader_ptr->print_c_condition (stdout, test->expr);
-   fputs ("\n    : -1 },\n", stdout);
-   return 1;
- }
-diff --git a/gcc/genpreds.cc b/gcc/genpreds.cc
-index 55d149e8a404..b8f3bf279d97 100644
---- a/gcc/genpreds.cc
-+++ b/gcc/genpreds.cc
-@@ -538,7 +538,7 @@ write_predicate_expr (rtx exp)
-       break;
- 
-     case MATCH_TEST:
--      rtx_reader_ptr->print_c_condition (XSTR (exp, 0));
-+      rtx_reader_ptr->print_c_condition (stdout, XSTR (exp, 0));
-       break;
- 
-     default:
-@@ -1344,7 +1344,7 @@ write_init_reg_class_start_regs ()
-       for (unsigned int i = 0; i < register_filters.length (); ++i)
- 	{
- 	  printf ("      if (");
--	  rtx_reader_ptr->print_c_condition (register_filters[i]);
-+	  rtx_reader_ptr->print_c_condition (stdout, register_filters[i]);
- 	  printf (")\n"
- 		  "        SET_HARD_REG_BIT (%s[%d], regno);\n",
- 		  "this_target_constraints->register_filters", i);
-diff --git a/gcc/genrecog.cc b/gcc/genrecog.cc
-index 719b1d44387e..1852ceba2513 100644
---- a/gcc/genrecog.cc
-+++ b/gcc/genrecog.cc
-@@ -4255,9 +4255,9 @@ match_pattern (state *s, md_rtx_info *info, rtx pattern,
- /* Begin the output file.  */
- 
- static void
--write_header (void)
-+write_header (FILE *f, const char *header_filename)
- {
--  puts ("\
-+  fprintf (f, "%s", "\
- /* Generated automatically by the program `genrecog' from the target\n\
-    machine description file.  */\n\
- \n\
-@@ -4281,10 +4281,12 @@ write_header (void)
- #include \"diagnostic-core.h\"\n\
- #include \"reload.h\"\n\
- #include \"regs.h\"\n\
--#include \"tm-constrs.h\"\n\
--\n");
-+#include \"tm-constrs.h\"\n");
- 
--  puts ("\n\
-+  fprintf (f, "#include \"%s\"\n", header_filename);
-+  fprintf (f, "%s", "\n");
-+
-+  fprintf (f, "%s", "\n\
- /* `recog' contains a decision tree that recognizes whether the rtx\n\
-    X0 is a valid instruction.\n\
- \n\
-@@ -4293,19 +4295,19 @@ write_header (void)
-    pattern that matched.  This is the same as the order in the machine\n\
-    description of the entry that matched.  This number can be used as an\n\
-    index into `insn_data' and other tables.\n");
--  puts ("\
-+  fprintf (f, "%s", "\
-    The third parameter to recog is an optional pointer to an int.  If\n\
-    present, recog will accept a pattern if it matches except for missing\n\
-    CLOBBER expressions at the end.  In that case, the value pointed to by\n\
-    the optional pointer will be set to the number of CLOBBERs that need\n\
-    to be added (it should be initialized to zero by the caller).  If it");
--  puts ("\
-+  fprintf (f, "%s", "\
-    is set nonzero, the caller should allocate a PARALLEL of the\n\
-    appropriate size, copy the initial entries, and call add_clobbers\n\
-    (found in insn-emit.cc) to fill in the CLOBBERs.\n\
- ");
- 
--  puts ("\n\
-+  fprintf (f, "%s", "\n\
-    The function split_insns returns 0 if the rtl could not\n\
-    be split or the split rtl as an INSN list if it can be.\n\
- \n\
-@@ -4463,13 +4465,13 @@ test_position_available_p (output_state *os, const rtx_test &test)
- 
- /* Like printf, but print INDENT spaces at the beginning.  */
- 
--static void ATTRIBUTE_PRINTF_2
--printf_indent (unsigned int indent, const char *format, ...)
-+static void ATTRIBUTE_PRINTF_3
-+printf_indent (FILE *f, unsigned int indent, const char *format, ...)
- {
-   va_list ap;
-   va_start (ap, format);
--  printf ("%*s", indent, "");
--  vprintf (format, ap);
-+  fprintf (f, "%*s", indent, "");
-+  vfprintf (f, format, ap);
-   va_end (ap);
- }
- 
-@@ -4478,7 +4480,7 @@ printf_indent (unsigned int indent, const char *format, ...)
-    OS with the new state.  */
- 
- static void
--change_state (output_state *os, position *pos, unsigned int indent)
-+change_state (FILE *f, output_state *os, position *pos, unsigned int indent)
- {
-   unsigned int var = os->id_to_var[pos->id];
-   gcc_assert (var < os->var_to_id.length () && os->var_to_id[var] == pos->id);
-@@ -4487,19 +4489,19 @@ change_state (output_state *os, position *pos, unsigned int indent)
-   switch (pos->type)
-     {
-     case POS_PEEP2_INSN:
--      printf_indent (indent, "x%d = PATTERN (peep2_next_insn (%d));\n",
-+      printf_indent (f, indent, "x%d = PATTERN (peep2_next_insn (%d));\n",
- 		     var, pos->arg);
-       break;
- 
-     case POS_XEXP:
--      change_state (os, pos->base, indent);
--      printf_indent (indent, "x%d = XEXP (x%d, %d);\n",
-+      change_state (f, os, pos->base, indent);
-+      printf_indent (f, indent, "x%d = XEXP (x%d, %d);\n",
- 		     var, os->id_to_var[pos->base->id], pos->arg);
-       break;
- 
-     case POS_XVECEXP0:
--      change_state (os, pos->base, indent);
--      printf_indent (indent, "x%d = XVECEXP (x%d, 0, %d);\n",
-+      change_state (f, os, pos->base, indent);
-+      printf_indent (f, indent, "x%d = XVECEXP (x%d, 0, %d);\n",
- 		     var, os->id_to_var[pos->base->id], pos->arg);
-       break;
-     }
-@@ -4510,11 +4512,11 @@ change_state (output_state *os, position *pos, unsigned int indent)
-    the name.  */
- 
- static void
--print_code (enum rtx_code code)
-+print_code (FILE *f, enum rtx_code code)
- {
-   const char *p;
-   for (p = GET_RTX_NAME (code); *p; p++)
--    putchar (TOUPPER (*p));
-+    fprintf (f, "%c", TOUPPER (*p));
- }
- 
- /* Emit a uint64_t as an integer constant expression.  We need to take
-@@ -4522,22 +4524,22 @@ print_code (enum rtx_code code)
-    warnings in the resulting code.  */
- 
- static void
--print_host_wide_int (uint64_t val)
-+print_host_wide_int (FILE *f, uint64_t val)
- {
-   uint64_t min = uint64_t (1) << (HOST_BITS_PER_WIDE_INT - 1);
-   if (val == min)
--    printf ("(" HOST_WIDE_INT_PRINT_DEC_C " - 1)", val + 1);
-+    fprintf (f, "(" HOST_WIDE_INT_PRINT_DEC_C " - 1)", val + 1);
-   else
--    printf (HOST_WIDE_INT_PRINT_DEC_C, val);
-+    fprintf (f, HOST_WIDE_INT_PRINT_DEC_C, val);
- }
- 
- /* Print the C expression for actual parameter PARAM.  */
- 
- static void
--print_parameter_value (const parameter ¶m)
-+print_parameter_value (FILE *f, const parameter ¶m)
- {
-   if (param.is_param)
--    printf ("i%d", (int) param.value + 1);
-+    fprintf (f, "i%d", (int) param.value + 1);
-   else
-     switch (param.type)
-       {
-@@ -4546,23 +4548,23 @@ print_parameter_value (const parameter ¶m)
- 	break;
- 
-       case parameter::CODE:
--	print_code ((enum rtx_code) param.value);
-+	print_code (f, (enum rtx_code) param.value);
- 	break;
- 
-       case parameter::MODE:
--	printf ("E_%smode", GET_MODE_NAME ((machine_mode) param.value));
-+	fprintf (f, "E_%smode", GET_MODE_NAME ((machine_mode) param.value));
- 	break;
- 
-       case parameter::INT:
--	printf ("%d", (int) param.value);
-+	fprintf (f, "%d", (int) param.value);
- 	break;
- 
-       case parameter::UINT:
--	printf ("%u", (unsigned int) param.value);
-+	fprintf (f, "%u", (unsigned int) param.value);
- 	break;
- 
-       case parameter::WIDE_INT:
--	print_host_wide_int (param.value);
-+	print_host_wide_int (f, param.value);
- 	break;
-       }
- }
-@@ -4570,90 +4572,90 @@ print_parameter_value (const parameter ¶m)
- /* Print the C expression for the rtx tested by TEST.  */
- 
- static void
--print_test_rtx (output_state *os, const rtx_test &test)
-+print_test_rtx (FILE *f, output_state *os, const rtx_test &test)
- {
-   if (test.pos_operand >= 0)
--    printf ("operands[%d]", test.pos_operand);
-+    fprintf (f, "operands[%d]", test.pos_operand);
-   else
--    printf ("x%d", os->id_to_var[test.pos->id]);
-+    fprintf (f, "x%d", os->id_to_var[test.pos->id]);
- }
- 
- /* Print the C expression for non-boolean test TEST.  */
- 
- static void
--print_nonbool_test (output_state *os, const rtx_test &test)
-+print_nonbool_test (FILE *f, output_state *os, const rtx_test &test)
- {
-   switch (test.kind)
-     {
-     case rtx_test::CODE:
--      printf ("GET_CODE (");
--      print_test_rtx (os, test);
--      printf (")");
-+      fprintf (f, "GET_CODE (");
-+      print_test_rtx (f, os, test);
-+      fprintf (f, ")");
-       break;
- 
-     case rtx_test::MODE:
--      printf ("GET_MODE (");
--      print_test_rtx (os, test);
--      printf (")");
-+      fprintf (f, "GET_MODE (");
-+      print_test_rtx (f, os, test);
-+      fprintf (f, ")");
-       break;
- 
-     case rtx_test::VECLEN:
--      printf ("XVECLEN (");
--      print_test_rtx (os, test);
--      printf (", 0)");
-+      fprintf (f, "XVECLEN (");
-+      print_test_rtx (f, os, test);
-+      fprintf (f, ", 0)");
-       break;
- 
-     case rtx_test::INT_FIELD:
--      printf ("XINT (");
--      print_test_rtx (os, test);
--      printf (", %d)", test.u.opno);
-+      fprintf (f, "XINT (");
-+      print_test_rtx (f, os, test);
-+      fprintf (f, ", %d)", test.u.opno);
-       break;
- 
-     case rtx_test::REGNO_FIELD:
--      printf ("REGNO (");
--      print_test_rtx (os, test);
--      printf (")");
-+      fprintf (f, "REGNO (");
-+      print_test_rtx (f, os, test);
-+      fprintf (f, ")");
-       break;
- 
-     case rtx_test::SUBREG_FIELD:
--      printf ("SUBREG_BYTE (");
--      print_test_rtx (os, test);
--      printf (")");
-+      fprintf (f, "SUBREG_BYTE (");
-+      print_test_rtx (f, os, test);
-+      fprintf (f, ")");
-       break;
- 
-     case rtx_test::WIDE_INT_FIELD:
--      printf ("XWINT (");
--      print_test_rtx (os, test);
--      printf (", %d)", test.u.opno);
-+      fprintf (f, "XWINT (");
-+      print_test_rtx (f, os, test);
-+      fprintf (f, ", %d)", test.u.opno);
-       break;
- 
-     case rtx_test::PATTERN:
-       {
- 	pattern_routine *routine = test.u.pattern->routine;
--	printf ("pattern%d (", routine->pattern_id);
-+	fprintf (f, "pattern%d (", routine->pattern_id);
- 	const char *sep = "";
- 	if (test.pos)
- 	  {
--	    print_test_rtx (os, test);
-+	    print_test_rtx (f, os, test);
- 	    sep = ", ";
- 	  }
- 	if (routine->insn_p)
- 	  {
--	    printf ("%sinsn", sep);
-+	    fprintf (f, "%sinsn", sep);
- 	    sep = ", ";
- 	  }
- 	if (routine->pnum_clobbers_p)
- 	  {
--	    printf ("%spnum_clobbers", sep);
-+	    fprintf (f, "%spnum_clobbers", sep);
- 	    sep = ", ";
- 	  }
- 	for (unsigned int i = 0; i < test.u.pattern->params.length (); ++i)
- 	  {
--	    fputs (sep, stdout);
--	    print_parameter_value (test.u.pattern->params[i]);
-+	    fprintf (f, "%s\n", sep);
-+	    print_parameter_value (f, test.u.pattern->params[i]);
- 	    sep = ", ";
- 	  }
--	printf (")");
-+	fprintf (f, ")");
- 	break;
-       }
- 
-@@ -4674,10 +4676,11 @@ print_nonbool_test (output_state *os, const rtx_test &test)
-    decision performs TEST.  Print the C code for the label.  */
- 
- static void
--print_label_value (const rtx_test &test, bool is_param, uint64_t value)
-+print_label_value (FILE *f, const rtx_test &test, bool is_param,
-+		   uint64_t value)
- {
--  print_parameter_value (parameter (transition_parameter_type (test.kind),
--				    is_param, value));
-+  print_parameter_value (f, parameter (transition_parameter_type (test.kind),
-+				       is_param, value));
- }
- 
- /* If IS_PARAM, print code to compare TEST with the C variable i<VALUE+1>.
-@@ -4685,7 +4688,7 @@ print_label_value (const rtx_test &test, bool is_param, uint64_t value)
-    Test for inequality if INVERT_P, otherwise test for equality.  */
- 
- static void
--print_test (output_state *os, const rtx_test &test, bool is_param,
-+print_test (FILE *f, output_state *os, const rtx_test &test, bool is_param,
- 	    uint64_t value, bool invert_p)
- {
-   switch (test.kind)
-@@ -4698,71 +4701,71 @@ print_test (output_state *os, const rtx_test &test, bool is_param,
-     case rtx_test::INT_FIELD:
-     case rtx_test::WIDE_INT_FIELD:
-     case rtx_test::PATTERN:
--      print_nonbool_test (os, test);
--      printf (" %s ", invert_p ? "!=" : "==");
--      print_label_value (test, is_param, value);
-+      print_nonbool_test (f, os, test);
-+      fprintf (f, " %s ", invert_p ? "!=" : "==");
-+      print_label_value (f, test, is_param, value);
-       break;
- 
-     case rtx_test::SUBREG_FIELD:
--      printf ("%s (", invert_p ? "maybe_ne" : "known_eq");
--      print_nonbool_test (os, test);
--      printf (", ");
--      print_label_value (test, is_param, value);
--      printf (")");
-+      fprintf (f, "%s (", invert_p ? "maybe_ne" : "known_eq");
-+      print_nonbool_test (f, os, test);
-+      fprintf (f, ", ");
-+      print_label_value (f, test, is_param, value);
-+      fprintf (f, ")");
-       break;
- 
-     case rtx_test::SAVED_CONST_INT:
-       gcc_assert (!is_param && value == 1);
--      print_test_rtx (os, test);
--      printf (" %s const_int_rtx[MAX_SAVED_CONST_INT + ",
--	      invert_p ? "!=" : "==");
--      print_parameter_value (parameter (parameter::INT,
--					test.u.integer.is_param,
--					test.u.integer.value));
--      printf ("]");
-+      print_test_rtx (f, os, test);
-+      fprintf (f, " %s const_int_rtx[MAX_SAVED_CONST_INT + ",
-+	       invert_p ? "!=" : "==");
-+      print_parameter_value (f, parameter (parameter::INT,
-+					   test.u.integer.is_param,
-+					   test.u.integer.value));
-+      fprintf (f, "]");
-       break;
- 
-     case rtx_test::PEEP2_COUNT:
-       gcc_assert (!is_param && value == 1);
--      printf ("peep2_current_count %s %d", invert_p ? "<" : ">=",
--	      test.u.min_len);
-+      fprintf (f, "peep2_current_count %s %d", invert_p ? "<" : ">=",
-+	       test.u.min_len);
-       break;
- 
-     case rtx_test::VECLEN_GE:
-       gcc_assert (!is_param && value == 1);
--      printf ("XVECLEN (");
--      print_test_rtx (os, test);
--      printf (", 0) %s %d", invert_p ? "<" : ">=", test.u.min_len);
-+      fprintf (f, "XVECLEN (");
-+      print_test_rtx (f, os, test);
-+      fprintf (f, ", 0) %s %d", invert_p ? "<" : ">=", test.u.min_len);
-       break;
- 
-     case rtx_test::PREDICATE:
-       gcc_assert (!is_param && value == 1);
--      printf ("%s%s (", invert_p ? "!" : "", test.u.predicate.data->name);
--      print_test_rtx (os, test);
--      printf (", ");
--      print_parameter_value (parameter (parameter::MODE,
--					test.u.predicate.mode_is_param,
--					test.u.predicate.mode));
--      printf (")");
-+      fprintf (f, "%s%s (", invert_p ? "!" : "", test.u.predicate.data->name);
-+      print_test_rtx (f, os, test);
-+      fprintf (f, ", ");
-+      print_parameter_value (f, parameter (parameter::MODE,
-+					   test.u.predicate.mode_is_param,
-+					   test.u.predicate.mode));
-+      fprintf (f, ")");
-       break;
- 
-     case rtx_test::DUPLICATE:
-       gcc_assert (!is_param && value == 1);
--      printf ("%srtx_equal_p (", invert_p ? "!" : "");
--      print_test_rtx (os, test);
--      printf (", operands[%d])", test.u.opno);
-+      fprintf (f, "%srtx_equal_p (", invert_p ? "!" : "");
-+      print_test_rtx (f, os, test);
-+      fprintf (f, ", operands[%d])", test.u.opno);
-       break;
- 
-     case rtx_test::HAVE_NUM_CLOBBERS:
-       gcc_assert (!is_param && value == 1);
--      printf ("pnum_clobbers %s NULL", invert_p ? "==" : "!=");
-+      fprintf (f, "pnum_clobbers %s NULL", invert_p ? "==" : "!=");
-       break;
- 
-     case rtx_test::C_TEST:
-       gcc_assert (!is_param && value == 1);
-       if (invert_p)
--	printf ("!");
--      rtx_reader_ptr->print_c_condition (test.u.string);
-+	fprintf (f, "!");
-+      rtx_reader_ptr->print_c_condition (f, test.u.string);
-       break;
- 
-     case rtx_test::ACCEPT:
-@@ -4771,7 +4774,7 @@ print_test (output_state *os, const rtx_test &test, bool is_param,
-     }
- }
- 
--static exit_state print_decision (output_state *, decision *,
-+static exit_state print_decision (FILE *f, output_state *, decision *,
- 				  unsigned int, bool);
- 
- /* Print code to perform S, indent each line by INDENT spaces.
-@@ -4779,14 +4782,15 @@ static exit_state print_decision (output_state *, decision *,
-    if the state fails then the entire routine fails.  */
- 
- static exit_state
--print_state (output_state *os, state *s, unsigned int indent, bool is_final)
-+print_state (FILE *f, output_state *os, state *s, unsigned int indent,
-+	     bool is_final)
- {
-   exit_state es = ES_FALLTHROUGH;
-   for (decision *d = s->first; d; d = d->next)
--    es = print_decision (os, d, indent, is_final && !d->next);
-+    es = print_decision (f, os, d, indent, is_final && !d->next);
-   if (es != ES_RETURNED && is_final)
-     {
--      printf_indent (indent, "return %s;\n", get_failure_return (os->type));
-+      printf_indent (f, indent, "return %s;\n", get_failure_return (os->type));
-       es = ES_RETURNED;
-     }
-   return es;
-@@ -4797,7 +4801,7 @@ print_state (output_state *os, state *s, unsigned int indent, bool is_final)
-    match.  */
- 
- static const char *
--print_subroutine_call (const acceptance_type &acceptance)
-+print_subroutine_call (FILE *f, const acceptance_type &acceptance)
- {
-   switch (acceptance.type)
-     {
-@@ -4805,17 +4809,17 @@ print_subroutine_call (const acceptance_type &acceptance)
-       gcc_unreachable ();
- 
-     case RECOG:
--      printf ("recog_%d (x1, insn, pnum_clobbers)",
--	      acceptance.u.subroutine_id);
-+      fprintf (f, "recog_%d (x1, insn, pnum_clobbers)",
-+	       acceptance.u.subroutine_id);
-       return ">= 0";
- 
-     case SPLIT:
--      printf ("split_%d (x1, insn)", acceptance.u.subroutine_id);
-+      fprintf (f, "split_%d (x1, insn)", acceptance.u.subroutine_id);
-       return "!= NULL_RTX";
- 
-     case PEEPHOLE2:
--      printf ("peephole2_%d (x1, insn, pmatch_len_)",
--	      acceptance.u.subroutine_id);
-+      fprintf (f, "peephole2_%d (x1, insn, pmatch_len_)",
-+	       acceptance.u.subroutine_id);
-       return "!= NULL_RTX";
-     }
-   gcc_unreachable ();
-@@ -4825,63 +4829,65 @@ print_subroutine_call (const acceptance_type &acceptance)
-    INDENT and IS_FINAL are as for print_state.  */
- 
- static exit_state
--print_acceptance (const acceptance_type &acceptance, unsigned int indent,
--		  bool is_final)
-+print_acceptance (FILE *f, const acceptance_type &acceptance,
-+		  unsigned int indent, bool is_final)
- {
-   if (acceptance.partial_p)
-     {
-       /* Defer the rest of the match to a subroutine.  */
-       if (is_final)
- 	{
--	  printf_indent (indent, "return ");
--	  print_subroutine_call (acceptance);
--	  printf (";\n");
-+	  printf_indent (f, indent, "return ");
-+	  print_subroutine_call (f, acceptance);
-+	  fprintf (f, ";\n");
- 	  return ES_RETURNED;
- 	}
-       else
- 	{
--	  printf_indent (indent, "res = ");
--	  const char *res_test = print_subroutine_call (acceptance);
--	  printf (";\n");
--	  printf_indent (indent, "if (res %s)\n", res_test);
--	  printf_indent (indent + 2, "return res;\n");
-+	  printf_indent (f, indent, "res = ");
-+	  const char *res_test = print_subroutine_call (f, acceptance);
-+	  fprintf (f, ";\n");
-+	  printf_indent (f, indent, "if (res %s)\n", res_test);
-+	  printf_indent (f, indent + 2, "return res;\n");
- 	  return ES_FALLTHROUGH;
- 	}
-     }
-   switch (acceptance.type)
-     {
-     case SUBPATTERN:
--      printf_indent (indent, "return %d;\n", acceptance.u.full.code);
-+      printf_indent (f, indent, "return %d;\n", acceptance.u.full.code);
-       return ES_RETURNED;
- 
-     case RECOG:
-       if (acceptance.u.full.u.num_clobbers != 0)
--	printf_indent (indent, "*pnum_clobbers = %d;\n",
-+	printf_indent (f, indent, "*pnum_clobbers = %d;\n",
- 		       acceptance.u.full.u.num_clobbers);
--      printf_indent (indent, "return %d; /* %s */\n", acceptance.u.full.code,
-+      printf_indent (f, indent, "return %d; /* %s */\n", acceptance.u.full.code,
- 		     get_insn_name (acceptance.u.full.code));
-       return ES_RETURNED;
- 
-     case SPLIT:
--      printf_indent (indent, "return gen_split_%d (insn, operands);\n",
-+      printf_indent (f, indent, "return gen_split_%d (insn, operands);\n",
- 		     acceptance.u.full.code);
-       return ES_RETURNED;
- 
-     case PEEPHOLE2:
--      printf_indent (indent, "*pmatch_len_ = %d;\n",
-+      printf_indent (f, indent, "*pmatch_len_ = %d;\n",
- 		     acceptance.u.full.u.match_len);
-       if (is_final)
- 	{
--	  printf_indent (indent, "return gen_peephole2_%d (insn, operands);\n",
-+	  printf_indent (f, indent,
-+			 "return gen_peephole2_%d (insn, operands);\n",
- 			 acceptance.u.full.code);
- 	  return ES_RETURNED;
- 	}
-       else
- 	{
--	  printf_indent (indent, "res = gen_peephole2_%d (insn, operands);\n",
-+	  printf_indent (f,
-+			 indent, "res = gen_peephole2_%d (insn, operands);\n",
- 			 acceptance.u.full.code);
--	  printf_indent (indent, "if (res != NULL_RTX)\n");
--	  printf_indent (indent + 2, "return res;\n");
-+	  printf_indent (f, indent, "if (res != NULL_RTX)\n");
-+	  printf_indent (f, indent + 2, "return res;\n");
- 	  return ES_FALLTHROUGH;
- 	}
-     }
-@@ -4891,7 +4897,7 @@ print_acceptance (const acceptance_type &acceptance, unsigned int indent,
- /* Print code to perform D.  INDENT and IS_FINAL are as for print_state.  */
- 
- static exit_state
--print_decision (output_state *os, decision *d, unsigned int indent,
-+print_decision (FILE *f, output_state *os, decision *d, unsigned int indent,
- 		bool is_final)
- {
-   uint64_t label;
-@@ -4900,7 +4906,7 @@ print_decision (output_state *os, decision *d, unsigned int indent,
-   /* Make sure the rtx under test is available either in operands[] or
-      in an xN variable.  */
-   if (d->test.pos && d->test.pos_operand < 0)
--    change_state (os, d->test.pos, indent);
-+    change_state (f, os, d->test.pos, indent);
- 
-   /* Look for cases where a pattern routine P1 calls another pattern routine
-      P2 and where P1 returns X + BASE whenever P2 returns X.  If IS_FINAL
-@@ -4924,32 +4930,32 @@ print_decision (output_state *os, decision *d, unsigned int indent,
-     {
-       if (is_final && base == 0)
- 	{
--	  printf_indent (indent, "return ");
--	  print_nonbool_test (os, d->test);
--	  printf ("; /* [-1, %d] */\n", count - 1);
-+	  printf_indent (f, indent, "return ");
-+	  print_nonbool_test (f, os, d->test);
-+	  fprintf (f, "; /* [-1, %d] */\n", count - 1);
- 	  return ES_RETURNED;
- 	}
-       else
- 	{
--	  printf_indent (indent, "res = ");
--	  print_nonbool_test (os, d->test);
--	  printf (";\n");
--	  printf_indent (indent, "if (res >= 0)\n");
--	  printf_indent (indent + 2, "return res");
-+	  printf_indent (f, indent, "res = ");
-+	  print_nonbool_test (f, os, d->test);
-+	  fprintf (f, ";\n");
-+	  printf_indent (f, indent, "if (res >= 0)\n");
-+	  printf_indent (f, indent + 2, "return res");
- 	  if (base != 0)
--	    printf (" + %d", base);
--	  printf ("; /* [%d, %d] */\n", base, base + count - 1);
-+	    fprintf (f, " + %d", base);
-+	  fprintf (f, "; /* [%d, %d] */\n", base, base + count - 1);
- 	  return ES_FALLTHROUGH;
- 	}
-     }
-   else if (d->test.kind == rtx_test::ACCEPT)
--    return print_acceptance (d->test.u.acceptance, indent, is_final);
-+    return print_acceptance (f, d->test.u.acceptance, indent, is_final);
-   else if (d->test.kind == rtx_test::SET_OP)
-     {
--      printf_indent (indent, "operands[%d] = ", d->test.u.opno);
--      print_test_rtx (os, d->test);
--      printf (";\n");
--      return print_state (os, d->singleton ()->to, indent, is_final);
-+      printf_indent (f, indent, "operands[%d] = ", d->test.u.opno);
-+      print_test_rtx (f, os, d->test);
-+      fprintf (f, ";\n");
-+      return print_state (f, os, d->singleton ()->to, indent, is_final);
-     }
-   /* Handle decisions with a single transition and a single transition
-      label.  */
-@@ -4957,13 +4963,13 @@ print_decision (output_state *os, decision *d, unsigned int indent,
-     {
-       transition *trans = d->singleton ();
-       if (mark_optional_transitions_p && trans->optional)
--	printf_indent (indent, "/* OPTIONAL IF */\n");
-+	printf_indent (f, indent, "/* OPTIONAL IF */\n");
- 
-       /* Print the condition associated with TRANS.  Invert it if IS_FINAL,
- 	 so that we return immediately on failure and fall through on
- 	 success.  */
--      printf_indent (indent, "if (");
--      print_test (os, d->test, trans->is_param, label, is_final);
-+      printf_indent (f, indent, "if (");
-+      print_test (f, os, d->test, trans->is_param, label, is_final);
- 
-       /* Look for following states that would be handled by this code
- 	 on recursion.  If they don't need any preparatory statements,
-@@ -4979,13 +4985,13 @@ print_decision (output_state *os, decision *d, unsigned int indent,
- 	      || !test_position_available_p (os, d->test))
- 	    break;
- 	  trans = d->first;
--	  printf ("\n");
-+	  fprintf (f, "\n");
- 	  if (mark_optional_transitions_p && trans->optional)
--	    printf_indent (indent + 4, "/* OPTIONAL IF */\n");
--	  printf_indent (indent + 4, "%s ", is_final ? "||" : "&&");
--	  print_test (os, d->test, trans->is_param, label, is_final);
-+	    printf_indent (f, indent + 4, "/* OPTIONAL IF */\n");
-+	  printf_indent (f, indent + 4, "%s ", is_final ? "||" : "&&");
-+	  print_test (f, os, d->test, trans->is_param, label, is_final);
- 	}
--      printf (")\n");
-+      fprintf (f, ")\n");
- 
-       /* Print the conditional code with INDENT + 2 and the fallthrough
- 	 code with indent INDENT.  */
-@@ -4994,9 +5000,9 @@ print_decision (output_state *os, decision *d, unsigned int indent,
- 	{
- 	  /* We inverted the condition above, so return failure in the
- 	     "if" body and fall through to the target of the transition.  */
--	  printf_indent (indent + 2, "return %s;\n",
-+	  printf_indent (f, indent + 2, "return %s;\n",
- 			 get_failure_return (os->type));
--	  return print_state (os, to, indent, is_final);
-+	  return print_state (f, os, to, indent, is_final);
- 	}
-       else if (to->singleton ()
- 	       && to->first->test.kind == rtx_test::ACCEPT
-@@ -5004,7 +5010,7 @@ print_decision (output_state *os, decision *d, unsigned int indent,
- 	{
- 	  /* The target of the transition is a simple "return" statement.
- 	     It doesn't need any braces and doesn't fall through.  */
--	  if (print_acceptance (to->first->test.u.acceptance,
-+	  if (print_acceptance (f, to->first->test.u.acceptance,
- 				indent + 2, true) != ES_RETURNED)
- 	    gcc_unreachable ();
- 	  return ES_FALLTHROUGH;
-@@ -5018,9 +5024,9 @@ print_decision (output_state *os, decision *d, unsigned int indent,
- 	  auto_vec <bool, 32> old_seen;
- 	  old_seen.safe_splice (os->seen_vars);
- 
--	  printf_indent (indent + 2, "{\n");
--	  print_state (os, trans->to, indent + 4, is_final);
--	  printf_indent (indent + 2, "}\n");
-+	  printf_indent (f, indent + 2, "{\n");
-+	  print_state (f, os, trans->to, indent + 4, is_final);
-+	  printf_indent (f, indent + 2, "}\n");
- 
- 	  os->seen_vars.truncate (0);
- 	  os->seen_vars.splice (old_seen);
-@@ -5030,48 +5036,48 @@ print_decision (output_state *os, decision *d, unsigned int indent,
-   else
-     {
-       /* Output the decision as a switch statement.  */
--      printf_indent (indent, "switch (");
--      print_nonbool_test (os, d->test);
--      printf (")\n");
-+      printf_indent (f, indent, "switch (");
-+      print_nonbool_test (f, os, d->test);
-+      fprintf (f, ")\n");
- 
-       /* Each case statement starts with the same set of valid variables.
- 	 These are also the only variables will be valid on fallthrough.  */
-       auto_vec <bool, 32> old_seen;
-       old_seen.safe_splice (os->seen_vars);
- 
--      printf_indent (indent + 2, "{\n");
-+      printf_indent (f, indent + 2, "{\n");
-       for (transition *trans = d->first; trans; trans = trans->next)
- 	{
- 	  gcc_assert (!trans->is_param);
- 	  if (mark_optional_transitions_p && trans->optional)
--	    printf_indent (indent + 2, "/* OPTIONAL CASE */\n");
-+	    printf_indent (f, indent + 2, "/* OPTIONAL CASE */\n");
- 	  for (int_set::iterator j = trans->labels.begin ();
- 	       j != trans->labels.end (); ++j)
- 	    {
--	      printf_indent (indent + 2, "case ");
--	      print_label_value (d->test, trans->is_param, *j);
--	      printf (":\n");
-+	      printf_indent (f, indent + 2, "case ");
-+	      print_label_value (f, d->test, trans->is_param, *j);
-+	      fprintf (f, ":\n");
- 	    }
--	  if (print_state (os, trans->to, indent + 4, is_final))
-+	  if (print_state (f, os, trans->to, indent + 4, is_final))
- 	    {
- 	      /* The state can fall through.  Add an explicit break.  */
- 	      gcc_assert (!is_final);
--	      printf_indent (indent + 4, "break;\n");
-+	      printf_indent (f, indent + 4, "break;\n");
- 	    }
--	  printf ("\n");
-+	  fprintf (f, "\n");
- 
- 	  /* Restore the original set of valid variables.  */
- 	  os->seen_vars.truncate (0);
- 	  os->seen_vars.splice (old_seen);
- 	}
-       /* Add a default case.  */
--      printf_indent (indent + 2, "default:\n");
-+      printf_indent (f, indent + 2, "default:\n");
-       if (is_final)
--	printf_indent (indent + 4, "return %s;\n",
-+	printf_indent (f, indent + 4, "return %s;\n",
- 		       get_failure_return (os->type));
-       else
--	printf_indent (indent + 4, "break;\n");
--      printf_indent (indent + 2, "}\n");
-+	printf_indent (f, indent + 4, "break;\n");
-+      printf_indent (f, indent + 2, "}\n");
-       return is_final ? ES_RETURNED : ES_FALLTHROUGH;
-     }
- }
-@@ -5114,10 +5120,10 @@ assign_position_vars (output_state *os, state *s)
-    only ROOT's variable has a valid value.  */
- 
- static void
--print_subroutine_start (output_state *os, state *s, position *root)
-+print_subroutine_start (FILE *f, output_state *os, state *s, position *root)
- {
--  printf ("{\n  rtx * const operands ATTRIBUTE_UNUSED"
--	  " = &recog_data.operand[0];\n");
-+  fprintf (f, "{\n  rtx * const operands ATTRIBUTE_UNUSED"
-+	   " = &recog_data.operand[0];\n");
-   os->var_to_id.truncate (0);
-   os->seen_vars.truncate (0);
-   if (root)
-@@ -5140,9 +5146,9 @@ print_subroutine_start (output_state *os, state *s, position *root)
- 	{
- 	  for (unsigned int i = 2; i < num_vars; ++i)
- 	    /* Print 8 rtx variables to a line.  */
--	    printf ("%s x%d",
-+	    fprintf (f, "%s x%d",
- 		    i == 2 ? "  rtx" : (i - 2) % 8 == 0 ? ";\n  rtx" : ",", i);
--	  printf (";\n");
-+	  fprintf (f, ";\n");
- 	}
- 
-       /* Say that x1 is valid and the rest aren't.  */
-@@ -5150,22 +5156,26 @@ print_subroutine_start (output_state *os, state *s, position *root)
-       os->seen_vars[1] = true;
-     }
-   if (os->type == SUBPATTERN || os->type == RECOG)
--    printf ("  int res ATTRIBUTE_UNUSED;\n");
-+    fprintf (f, "  int res ATTRIBUTE_UNUSED;\n");
-   else
--    printf ("  rtx_insn *res ATTRIBUTE_UNUSED;\n");
-+    fprintf (f, "  rtx_insn *res ATTRIBUTE_UNUSED;\n");
- }
- 
- /* Output the definition of pattern routine ROUTINE.  */
- 
- static void
--print_pattern (output_state *os, pattern_routine *routine)
-+print_pattern (FILE *f, output_state *os, pattern_routine *routine,
-+	       bool in_header = false)
- {
--  printf ("\nstatic int\npattern%d (", routine->pattern_id);
-+  if (!in_header)
-+    fprintf (f, "\nint\npattern%d (", routine->pattern_id);
-+  else
-+    fprintf (f, "\nextern int\npattern%d (", routine->pattern_id);
-   const char *sep = "";
-   /* Add the top-level rtx parameter, if any.  */
-   if (routine->pos)
-     {
--      printf ("%srtx x1", sep);
-+      fprintf (f, "%srtx x1", sep);
-       sep = ", ";
-     }
-   /* Add the optional parameters.  */
-@@ -5173,26 +5183,34 @@ print_pattern (output_state *os, pattern_routine *routine)
-     {
-       /* We can't easily tell whether a C condition actually reads INSN,
- 	 so add an ATTRIBUTE_UNUSED just in case.  */
--      printf ("%srtx_insn *insn ATTRIBUTE_UNUSED", sep);
-+      fprintf (f, "%srtx_insn *insn ATTRIBUTE_UNUSED", sep);
-       sep = ", ";
-     }
-   if (routine->pnum_clobbers_p)
-     {
--      printf ("%sint *pnum_clobbers", sep);
-+      fprintf (f, "%sint *pnum_clobbers", sep);
-       sep = ", ";
-     }
-   /* Add the "i" parameters.  */
-   for (unsigned int i = 0; i < routine->param_types.length (); ++i)
-     {
--      printf ("%s%s i%d", sep,
--	      parameter_type_string (routine->param_types[i]), i + 1);
-+      fprintf (f, "%s%s i%d", sep,
-+	       parameter_type_string (routine->param_types[i]), i + 1);
-       sep = ", ";
-     }
--  printf (")\n");
-+
-+  if (!in_header)
-+    fprintf (f, ")\n");
-+  else
-+    {
-+      fprintf (f, ");\n");
-+      return;
-+    }
-+
-   os->type = SUBPATTERN;
--  print_subroutine_start (os, routine->s, routine->pos);
--  print_state (os, routine->s, 2, true);
--  printf ("}\n");
-+  print_subroutine_start (f, os, routine->s, routine->pos);
-+  print_state (f, os, routine->s, 2, true);
-+  fprintf (f, "}\n");
- }
- 
- /* Output a routine of type TYPE that implements S.  PROC_ID is the
-@@ -5200,9 +5218,26 @@ print_pattern (output_state *os, pattern_routine *routine)
-    routine.  */
- 
- static void
--print_subroutine (output_state *os, state *s, int proc_id)
--{
--  printf ("\n");
-+print_subroutine (FILE *f, output_state *os, state *s, int proc_id,
-+		  bool in_header = false)
-+{
-+  fprintf (f, "\n");
-+  const char *specifier_ext = "extern";
-+  const char *specifier_default = "";
-+  const char *specifier;
-+  if (!in_header)
-+    specifier = specifier_default;
-+  else
-+    specifier = specifier_ext;
-+
-+  const char *end;
-+  const char *end_default = "";
-+  const char *end_header = ";";
-+  if (!in_header)
-+    end = end_default;
-+  else
-+    end = end_header;
-+
-   switch (os->type)
-     {
-     case SUBPATTERN:
-@@ -5210,46 +5245,54 @@ print_subroutine (output_state *os, state *s, int proc_id)
- 
-     case RECOG:
-       if (proc_id)
--	printf ("static int\nrecog_%d", proc_id);
-+	fprintf (f, "%s int\nrecog_%d", specifier, proc_id);
-       else
--	printf ("int\nrecog");
--      printf (" (rtx x1 ATTRIBUTE_UNUSED,\n"
--	      "\trtx_insn *insn ATTRIBUTE_UNUSED,\n"
--	      "\tint *pnum_clobbers ATTRIBUTE_UNUSED)\n");
-+	fprintf (f, "%s int\nrecog", specifier);
-+      fprintf (f, " (rtx x1 ATTRIBUTE_UNUSED,\n"
-+	       "\trtx_insn *insn ATTRIBUTE_UNUSED,\n"
-+	       "\tint *pnum_clobbers ATTRIBUTE_UNUSED)%s\n", end);
-       break;
- 
-     case SPLIT:
-       if (proc_id)
--	printf ("static rtx_insn *\nsplit_%d", proc_id);
-+	fprintf (f, "%s rtx_insn *\nsplit_%d", specifier, proc_id);
-       else
--	printf ("rtx_insn *\nsplit_insns");
--      printf (" (rtx x1 ATTRIBUTE_UNUSED, rtx_insn *insn ATTRIBUTE_UNUSED)\n");
-+	fprintf (f, "%s rtx_insn *\nsplit_insns", specifier);
-+      fprintf (f, " (rtx x1 ATTRIBUTE_UNUSED, "
-+		  "rtx_insn *insn ATTRIBUTE_UNUSED)%s\n", end);
-       break;
- 
-     case PEEPHOLE2:
-       if (proc_id)
--	printf ("static rtx_insn *\npeephole2_%d", proc_id);
-+	fprintf (f, "%s rtx_insn *\npeephole2_%d", specifier, proc_id);
-       else
--	printf ("rtx_insn *\npeephole2_insns");
--      printf (" (rtx x1 ATTRIBUTE_UNUSED,\n"
--	      "\trtx_insn *insn ATTRIBUTE_UNUSED,\n"
--	      "\tint *pmatch_len_ ATTRIBUTE_UNUSED)\n");
-+	fprintf (f, "%s rtx_insn *\npeephole2_insns", specifier);
-+      fprintf (f, " (rtx x1 ATTRIBUTE_UNUSED,\n"
-+	       "\trtx_insn *insn ATTRIBUTE_UNUSED,\n"
-+	       "\tint *pmatch_len_ ATTRIBUTE_UNUSED)%s\n", end);
-       break;
-     }
--  print_subroutine_start (os, s, &root_pos);
-+
-+  if (in_header)
-+    return;
-+
-+  print_subroutine_start (f, os, s, &root_pos);
-   if (proc_id == 0)
-     {
--      printf ("  recog_data.insn = NULL;\n");
-+      fprintf (f, "  recog_data.insn = NULL;\n");
-     }
--  print_state (os, s, 2, true);
--  printf ("}\n");
-+  print_state (f, os, s, 2, true);
-+  fprintf (f, "}\n");
- }
- 
- /* Print out a routine of type TYPE that performs ROOT.  */
- 
- static void
--print_subroutine_group (output_state *os, routine_type type, state *root)
-+print_subroutine_group (vec<FILE *> &vec, FILE *header, output_state *os,
-+			routine_type type, state *root)
- {
-+  FILE *f;
-+  unsigned idx;
-   os->type = type;
-   if (use_subroutines_p)
-     {
-@@ -5261,11 +5304,20 @@ print_subroutine_group (output_state *os, routine_type type, state *root)
-       /* Output the subroutines (but not ROOT itself).  */
-       unsigned int i;
-       state *s;
-+
-+      FILE *f = header;
-+      FOR_EACH_VEC_ELT (subroutines, i, s)
-+	print_subroutine (header, os, s, i + 1, true);
-+
-       FOR_EACH_VEC_ELT (subroutines, i, s)
--	print_subroutine (os, s, i + 1);
-+	{
-+	  f = choose_output (vec, idx);
-+	  print_subroutine (f, os, s, i + 1);
-+	}
-     }
-   /* Output the main routine.  */
--  print_subroutine (os, root, 0);
-+  f = choose_output (vec, idx);
-+  print_subroutine (f, os, root, 0);
- }
- 
- /* Return the rtx pattern for the list of rtxes in a define_peephole2.  */
-@@ -5336,6 +5388,29 @@ remove_clobbers (acceptance_type *acceptance_ptr, rtx *pattern_ptr)
-   return true;
- }
- 
-+auto_vec<FILE *, 10> output_files;
-+char header_name[255];
-+FILE *header = NULL;
-+
-+static bool
-+handle_arg (const char *arg)
-+{
-+  printf ("%s\n", arg);
-+  if (arg[1] == 'O')
-+    {
-+      FILE *file = fopen (&arg[2], "w");
-+      output_files.safe_push (file);
-+      return true;
-+    }
-+  if (arg[1] == 'H')
-+    {
-+      snprintf (header_name, 255, "%s", &arg[2]);
-+      header = fopen (header_name, "w");
-+      return true;
-+    }
-+  return false;
-+}
-+
- int
- main (int argc, const char **argv)
- {
-@@ -5343,10 +5418,17 @@ main (int argc, const char **argv)
- 
-   progname = "genrecog";
- 
--  if (!init_rtx_reader_args (argc, argv))
-+  if (!init_rtx_reader_args_cb (argc, argv, handle_arg))
-     return (FATAL_EXIT_CODE);
- 
--  write_header ();
-+  if (output_files.is_empty ())
-+    output_files.safe_push (stdout);
-+
-+  for (auto f : output_files)
-+    write_header (f, header_name);
-+
-+  FILE *file = NULL;
-+  unsigned file_idx;
- 
-   /* Read the machine description.  */
- 
-@@ -5354,6 +5436,7 @@ main (int argc, const char **argv)
-   while (read_md_rtx (&info))
-     {
-       rtx def = info.def;
-+      file = choose_output (output_files, file_idx);
- 
-       acceptance_type acceptance;
-       acceptance.partial_p = false;
-@@ -5387,8 +5470,8 @@ main (int argc, const char **argv)
- 
- 	  /* Declare the gen_split routine that we'll call if the
- 	     pattern matches.  The definition comes from insn-emit.cc.  */
--	  printf ("extern rtx_insn *gen_split_%d (rtx_insn *, rtx *);\n",
--		  info.index);
-+	  fprintf (header, "extern rtx_insn *gen_split_%d "
-+		   "(rtx_insn *, rtx *);\n", info.index);
- 	  break;
- 
- 	case DEFINE_PEEPHOLE2:
-@@ -5399,8 +5482,8 @@ main (int argc, const char **argv)
- 
- 	  /* Declare the gen_peephole2 routine that we'll call if the
- 	     pattern matches.  The definition comes from insn-emit.cc.  */
--	  printf ("extern rtx_insn *gen_peephole2_%d (rtx_insn *, rtx *);\n",
--		  info.index);
-+	  fprintf (header, "extern rtx_insn *gen_peephole2_%d "
-+		   "(rtx_insn *, rtx *);\n", info.index);
- 	  break;
- 
- 	default:
-@@ -5411,7 +5494,8 @@ main (int argc, const char **argv)
-   if (have_error)
-     return FATAL_EXIT_CODE;
- 
--  puts ("\n\n");
-+  for (auto f : output_files)
-+    fprintf (f, "%s", "\n\n");
- 
-   /* Optimize each routine in turn.  */
-   optimize_subroutine_group ("recog", &insn_root);
-@@ -5433,15 +5517,27 @@ main (int argc, const char **argv)
-       /* Print out the routines that we just created.  */
-       unsigned int i;
-       pattern_routine *routine;
-+
-       FOR_EACH_VEC_ELT (patterns, i, routine)
--	print_pattern (&os, routine);
-+	print_pattern (header, &os, routine, true);
-+
-+      FOR_EACH_VEC_ELT (patterns, i, routine)
-+	{
-+	  file = choose_output (output_files, file_idx);
-+	  print_pattern (file, &os, routine);
-+	}
-     }
- 
-   /* Print out the matching routines.  */
--  print_subroutine_group (&os, RECOG, &insn_root);
--  print_subroutine_group (&os, SPLIT, &split_root);
--  print_subroutine_group (&os, PEEPHOLE2, &peephole2_root);
-+  print_subroutine_group (output_files, header, &os, RECOG, &insn_root);
-+  print_subroutine_group (output_files, header, &os, SPLIT, &split_root);
-+  print_subroutine_group (output_files, header, &os, PEEPHOLE2, &peephole2_root);
-+
-+  fclose (header);
- 
--  fflush (stdout);
--  return (ferror (stdout) != 0 ? FATAL_EXIT_CODE : SUCCESS_EXIT_CODE);
-+  int ret = SUCCESS_EXIT_CODE;
-+  for (FILE *f : output_files)
-+    if (fclose (f) != 0)
-+      ret = FATAL_EXIT_CODE;
-+  return ret;
- }
-diff --git a/gcc/gentarget-def.cc b/gcc/gentarget-def.cc
-index 061b1e7247c1..3a462560cc1b 100644
---- a/gcc/gentarget-def.cc
-+++ b/gcc/gentarget-def.cc
-@@ -191,7 +191,7 @@ def_target_insn (const char *name, const char *prototype)
- 	      printf ("target_have_%s (void)\n", name);
- 	      printf ("{\n");
- 	      printf ("  return ");
--	      rtx_reader_ptr->print_c_condition (test);
-+	      rtx_reader_ptr->print_c_condition (stdout, test);
- 	      printf (";\n");
- 	      printf ("}\n");
- 	    }
-diff --git a/gcc/read-md.cc b/gcc/read-md.cc
-index 93d1ea437812..aeb1cced00d0 100644
---- a/gcc/read-md.cc
-+++ b/gcc/read-md.cc
-@@ -192,9 +192,9 @@ md_reader::fprint_c_condition (FILE *outf, const char *cond)
- /* Special fprint_c_condition for writing to STDOUT.  */
- 
- void
--md_reader::print_c_condition (const char *cond)
-+md_reader::print_c_condition (FILE *outf, const char *cond)
- {
--  fprint_c_condition (stdout, cond);
-+  fprint_c_condition (outf, cond);
- }
- 
- /* A vfprintf-like function for reporting an error against line LINENO
-diff --git a/gcc/read-md.h b/gcc/read-md.h
-index e613c42b7241..b42add391ed8 100644
---- a/gcc/read-md.h
-+++ b/gcc/read-md.h
-@@ -205,7 +205,7 @@ class md_reader
- 
-   const char *join_c_conditions (const char *cond1, const char *cond2);
-   void fprint_c_condition (FILE *outf, const char *cond);
--  void print_c_condition (const char *cond);
-+  void print_c_condition (FILE *outf, const char *cond);
- 
-   /* Defined in read-rtl.cc.  */
-   const char *apply_iterator_to_string (const char *string);
-
-base-commit: 6a5a1b8175e07ff578204476cd11115d8a071cbc
--- 
-2.47.1
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 8b73c10..b66566b 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 32	????
 
+	- 72_all_PR111600-genrecog-Split-into-separate-partitions.patch
 	- 74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
 	- 75_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array-2.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-16 15:14 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-16 15:14 UTC (permalink / raw
  To: gentoo-commits
commit:     814ca13216462c81498ecbefb2a25fe54b27c1bc
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 16 15:13:12 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Dec 16 15:13:16 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=814ca132
15.0.0: cut patchset 32
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index b66566b..e2217e1 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-32	????
+32	16 December 2024
 
 	- 72_all_PR111600-genrecog-Split-into-separate-partitions.patch
 	- 74_all_PR117724-Fix-type-compatibility-for-types-with-flexible-array.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-19 18:34 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-19 18:34 UTC (permalink / raw
  To: gentoo-commits
commit:     bf22395e91b68cb0cb464f72e08949ddd7ded9bf
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Dec 19 18:34:00 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Dec 19 18:34:00 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=bf22395e
15.0.0: drop 77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
Committed upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...7980-ICE-cxx_eval_outermost_constant_expr.patch | 130 ---------------------
 1 file changed, 130 deletions(-)
diff --git a/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch b/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
deleted file mode 100644
index f077536..0000000
--- a/15.0.0/gentoo/77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
+++ /dev/null
@@ -1,130 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/20241212184222.471783-1-polacek@redhat.com/
-
-From f9ec39fcb8905fad2aba87bf328f0d5934b2385d Mon Sep 17 00:00:00 2001
-Message-ID: <f9ec39fcb8905fad2aba87bf328f0d5934b2385d.1734066473.git.sam@gentoo.org>
-From: Marek Polacek <polacek@redhat.com>
-Date: Thu, 12 Dec 2024 13:42:22 -0500
-Subject: [PATCH] c++: ICE in TARGET_EXPR evaluation in cp_fold_r [PR117980]
-
-This ICE started with the recent prvalue optimization (r15-6052).  In
-cp_fold_r we have:
-
-      if (tree &init = TARGET_EXPR_INITIAL (stmt))
-        {
-          cp_walk_tree (&init, cp_fold_r, data, NULL);
-          // ...
-	  tree folded = maybe_constant_init (init, TARGET_EXPR_SLOT (stmt));
-
-What can happen here is that originally the TARGET_EXPR is:
-
-    TARGET_EXPR <D.2747, <<< Unknown tree: aggr_init_expr
-      5
-      __ct_comp
-      D.2747
-      (struct subrange *) <<< Unknown tree: void_cst >>>
-      &TARGET_EXPR <D.2707, {.it=TARGET_EXPR <D.2695, ...>}> >>>>
-
-but after the first cp_walk_tree we fold the D.2707 TARGET_EXPR into:
-
-    TARGET_EXPR <D.2707, <<< Unknown tree: expr_stmt
-      D.2707.it = TARGET_EXPR <D.2695, ...> >>>>
-
-and then we pass the EXPR_STMT to maybe_constant_init, with D.2707 as
-the object.  But their types don't match anymore, so we crash.  We'd
-have to pass D.2707.it as the object for it to work.
-
-But I don't think we need to pass any object to maybe_constant_init;
-it'll grab the appropriate one itself.
-
-constexpr-prvalue3.C is reduced from a large std::ranges libstdc++ test.
-
-	PR c++/117980
-
-gcc/cp/ChangeLog:
-
-	* cp-gimplify.cc (cp_fold_r) <case TARGET_EXPR>: Don't pass an object
-	to maybe_constant_init.
-
-gcc/testsuite/ChangeLog:
-
-* g++.dg/cpp0x/constexpr-prvalue2.C: New test.
-	* g++.dg/cpp0x/constexpr-prvalue3.C: New test.
----
- gcc/cp/cp-gimplify.cc                         |  2 +-
- .../g++.dg/cpp0x/constexpr-prvalue2.C         | 15 +++++++++++
- .../g++.dg/cpp0x/constexpr-prvalue3.C         | 26 +++++++++++++++++++
- 3 files changed, 42 insertions(+), 1 deletion(-)
- create mode 100644 gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue2.C
- create mode 100644 gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue3.C
-
-diff --git a/gcc/cp/cp-gimplify.cc b/gcc/cp/cp-gimplify.cc
-index 623e2ee6e964..a861331c7c7d 100644
---- a/gcc/cp/cp-gimplify.cc
-+++ b/gcc/cp/cp-gimplify.cc
-@@ -1477,7 +1477,7 @@ cp_fold_r (tree *stmt_p, int *walk_subtrees, void *data_)
- 	  *walk_subtrees = 0;
- 	  if (!flag_no_inline)
- 	    {
--	      tree folded = maybe_constant_init (init, TARGET_EXPR_SLOT (stmt));
-+	      tree folded = maybe_constant_init (init);
- 	      if (folded != init && TREE_CONSTANT (folded))
- 		init = folded;
- 	    }
-diff --git a/gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue2.C b/gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue2.C
-new file mode 100644
-index 000000000000..46053231cf83
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue2.C
-@@ -0,0 +1,15 @@
-+// PR c++/117980
-+// { dg-do compile { target c++11 } }
-+// { dg-options "-O" }
-+
-+struct S {
-+  constexpr S(S &); // { dg-warning "used but never defined" }
-+  ~S();
-+};
-+struct B {
-+  S s;
-+};
-+struct A {
-+  B b;
-+};
-+void fn(B b) { A{b}; }
-diff --git a/gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue3.C b/gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue3.C
-new file mode 100644
-index 000000000000..a2eb12c02d74
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/cpp0x/constexpr-prvalue3.C
-@@ -0,0 +1,26 @@
-+// PR c++/117980
-+// { dg-do compile { target c++11 } }
-+// { dg-options "-O" }
-+
-+struct _Safe_iterator  {
-+ _Safe_iterator();
-+  ~_Safe_iterator();
-+};
-+template <typename _Tp>
-+struct vector {
-+  vector(int) {}
-+  constexpr _Safe_iterator end() {
-+    return _Safe_iterator();
-+  }
-+};
-+template <typename It> struct sentinel {
-+  It it;
-+};
-+template <typename _Sent>
-+struct subrange {
-+  subrange(sentinel<_Safe_iterator>) {}
-+};
-+void test01() {
-+  vector<int> v{0};
-+  subrange<sentinel<_Safe_iterator>>{sentinel<_Safe_iterator>{v.end()}};
-+}
-
-base-commit: d136fa00f0d5faff8397edcd7e4ebb3445ab21b0
--- 
-2.47.1
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-20  1:55 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-20  1:55 UTC (permalink / raw
  To: gentoo-commits
commit:     f98ac56e7c38e054392b38f427cbfb04acf07c8f
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 20 01:55:05 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Dec 20 01:55:39 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=f98ac56e
15.0.0: add diagnostics patch for C23
Bug: https://gcc.gnu.org/PR118112
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...ovements-to-too-few-many-arguments-errors.patch | 630 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   5 +
 2 files changed, 635 insertions(+)
diff --git a/15.0.0/gentoo/77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch b/15.0.0/gentoo/77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
new file mode 100644
index 0000000..8688ac1
--- /dev/null
+++ b/15.0.0/gentoo/77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
@@ -0,0 +1,630 @@
+https://inbox.sourceware.org/gcc-patches/20241219234019.722392-1-dmalcolm@redhat.com/
+
+From b0525913499d305c2116e31bc6505ed67e87cf19 Mon Sep 17 00:00:00 2001
+Message-ID: <b0525913499d305c2116e31bc6505ed67e87cf19.1734659653.git.sam@gentoo.org>
+From: David Malcolm <dmalcolm@redhat.com>
+Date: Thu, 19 Dec 2024 18:40:19 -0500
+Subject: [PATCH] c/c++: UX improvements to 'too {few,many} arguments' errors
+ [PR118112]
+
+Consider this case of a bad call to a callback function (perhaps
+due to C23 changing the meaning of () in function decls):
+
+struct p {
+        int (*bar)();
+};
+
+void baz() {
+    struct p q;
+    q.bar(1);
+}
+
+Before this patch the C frontend emits:
+
+t.c: In function 'baz':
+t.c:7:5: error: too many arguments to function 'q.bar'
+    7 |     q.bar(1);
+      |     ^
+
+and the C++ frontend emits:
+
+t.c: In function 'void baz()':
+t.c:7:10: error: too many arguments to function
+    7 |     q.bar(1);
+      |     ~~~~~^~~
+
+neither of which give the user much help in terms of knowing what
+was expected, and where the relevant declaration is.
+
+With this patch the C frontend emits:
+
+t.c: In function 'baz':
+t.c:7:5: error: too many arguments to function 'q.bar'; expected 0, have 1
+    7 |     q.bar(1);
+      |     ^     ~
+t.c:2:15: note: declared here
+    2 |         int (*bar)();
+      |               ^~~
+
+(showing the expected vs actual counts, the pertinent field decl, and
+underlining the first extraneous argument at the callsite)
+
+and the C++ frontend emits:
+
+t.c: In function 'void baz()':
+t.c:7:10: error: too many arguments to function; expected 0, have 1
+    7 |     q.bar(1);
+      |     ~~~~~^~~
+
+(showing the expected vs actual counts; the other data was not accessible
+without a more invasive patch)
+
+Similarly, the patch also updates the "too few arguments" case to also
+show expected vs actual counts.  Doing so requires a tweak to the
+wording to say "at least" for the case of variadic fns, and for C++ fns
+with default args, where e.g. previously the C FE emitted:
+
+s.c: In function 'test':
+s.c:5:3: error: too few arguments to function 'callee'
+    5 |   callee ();
+      |   ^~~~~~
+s.c:1:6: note: declared here
+    1 | void callee (const char *, ...);
+      |      ^~~~~~
+
+with this patch it emits:
+
+s.c: In function 'test':
+s.c:5:3: error: too few arguments to function 'callee'; expected at least 1, have 0
+    5 |   callee ();
+      |   ^~~~~~
+s.c:1:6: note: declared here
+    1 | void callee (const char *, ...);
+      |      ^~~~~~
+
+Successfully bootstrapped & regrtested on x86_64-pc-linux-gnu.
+OK for trunk?
+
+gcc/c/ChangeLog:
+	PR c/118112
+	* c-typeck.cc (inform_declaration): Add "function_expr" param and
+	use it for cases where we couldn't show the function decl to show
+	field decls for callbacks.
+	(build_function_call_vec): Add missing auto_diagnostic_group.
+	Update for new param of inform_declaration.
+	(convert_arguments): Likewise.  For the "too many arguments" case
+	add the expected vs actual counts to the message, and if we have
+	it, add the location_t of the first surplus param as a secondary
+	location within the diagnostic.  For the "too few arguments" case,
+	determine the minimum number of arguments required and add the
+	expected vs actual counts to the message, tweaking it to "at least"
+	for variadic functions.
+
+gcc/cp/ChangeLog:
+	PR c/118112
+	* typeck.cc (error_args_num): Add params "expected_num",
+	"actual_num", and "at_least_p".  Compute "too_many_p" from these
+	rather than have it be a param.  Add expected vs actual counts to
+	the messages and tweak them for the "at least" case.
+	(convert_arguments): Update calls to error_args_num to pass in
+	expected vs actual number, and the "at_least_p", determining this
+	for the "too few" case.
+
+gcc/testsuite/ChangeLog:
+	PR c/118112
+	* c-c++-common/too-few-arguments.c: New test.
+	* c-c++-common/too-many-arguments.c: New test.
+	* g++.dg/cpp0x/variadic169.C: Verify the reported expected vs
+	actual argument counts.
+	* g++.dg/modules/macloc-1_c.C: Update regexp for addition of param
+	counts to error message.
+	* g++.dg/modules/macloc-1_d.C: Likewise.
+
+Signed-off-by: David Malcolm <dmalcolm@redhat.com>
+---
+ gcc/c/c-typeck.cc                             | 77 ++++++++++++---
+ gcc/cp/typeck.cc                              | 94 ++++++++++++++----
+ .../c-c++-common/too-few-arguments.c          | 38 ++++++++
+ .../c-c++-common/too-many-arguments.c         | 96 +++++++++++++++++++
+ gcc/testsuite/g++.dg/cpp0x/variadic169.C      |  2 +-
+ gcc/testsuite/g++.dg/modules/macloc-1_c.C     |  4 +-
+ gcc/testsuite/g++.dg/modules/macloc-1_d.C     |  4 +-
+ 7 files changed, 280 insertions(+), 35 deletions(-)
+ create mode 100644 gcc/testsuite/c-c++-common/too-few-arguments.c
+ create mode 100644 gcc/testsuite/c-c++-common/too-many-arguments.c
+
+diff --git a/gcc/c/c-typeck.cc b/gcc/c/c-typeck.cc
+index 9756edaae084..fff2bba06954 100644
+--- a/gcc/c/c-typeck.cc
++++ b/gcc/c/c-typeck.cc
+@@ -3737,14 +3737,30 @@ build_function_call (location_t loc, tree function, tree params)
+   return ret;
+ }
+ 
+-/* Give a note about the location of the declaration of DECL.  */
++/* Give a note about the location of the declaration of DECL,
++   or, failing that, a pertinent declaration for FUNCTION_EXPR.  */
+ 
+ static void
+-inform_declaration (tree decl)
++inform_declaration (tree decl, tree function_expr)
+ {
+   if (decl && (TREE_CODE (decl) != FUNCTION_DECL
+ 	       || !DECL_IS_UNDECLARED_BUILTIN (decl)))
+     inform (DECL_SOURCE_LOCATION (decl), "declared here");
++  else if (function_expr)
++    switch (TREE_CODE (function_expr))
++      {
++      default:
++	break;
++      case COMPONENT_REF:
++	/* Show the decl of the pertinent field (e.g. for callback
++	   fields in a struct.  */
++	{
++	  tree field_decl = TREE_OPERAND (function_expr, 1);
++	  if (location_t loc = DECL_SOURCE_LOCATION (field_decl))
++	    inform (loc, "declared here");
++	}
++	break;
++      }
+ }
+ 
+ /* C implementation of callback for use when checking param types.  */
+@@ -3819,10 +3835,11 @@ build_function_call_vec (location_t loc, vec<location_t> arg_loc,
+ 		  function);
+       else if (DECL_P (function))
+ 	{
++	  auto_diagnostic_group d;
+ 	  error_at (loc,
+ 		    "called object %qD is not a function or function pointer",
+ 		    function);
+-	  inform_declaration (function);
++	  inform_declaration (function, NULL_TREE);
+ 	}
+       else
+ 	error_at (loc,
+@@ -4276,25 +4293,37 @@ convert_arguments (location_t loc, vec<location_t> arg_loc, tree fntype,
+ 
+       if (type == void_type_node)
+ 	{
++	  auto_diagnostic_group d;
++	  int num_expected = parmnum;
++	  int num_actual = values->length ();
++	  gcc_rich_location rich_loc (loc);
++	  if (ploc != input_location)
++	    rich_loc.add_range (ploc);
+ 	  if (selector)
+-	    error_at (loc, "too many arguments to method %qE", selector);
++	    error_at (&rich_loc,
++		      "too many arguments to method %qE; expected %i, have %i",
++		      selector, num_expected, num_actual);
+ 	  else
+-	    error_at (loc, "too many arguments to function %qE", function);
+-	  inform_declaration (fundecl);
++	    error_at (&rich_loc,
++		      "too many arguments to function %qE; expected %i, have %i",
++		      function, num_expected, num_actual);
++	  inform_declaration (fundecl, function);
+ 	  return error_args ? -1 : (int) parmnum;
+ 	}
+ 
+       if (builtin_type == void_type_node)
+ 	{
++	  auto_diagnostic_group d;
+ 	  if (warning_at (loc, OPT_Wbuiltin_declaration_mismatch,
+ 			  "too many arguments to built-in function %qE "
+ 			  "expecting %d", function, parmnum))
+-	    inform_declaration (fundecl);
++	    inform_declaration (fundecl, function);
+ 	  builtin_typetail = NULL_TREE;
+ 	}
+ 
+       if (!typetail && parmnum == 0 && !TYPE_NO_NAMED_ARGS_STDARG_P (fntype))
+ 	{
++	  auto_diagnostic_group d;
+ 	  bool warned;
+ 	  if (selector)
+ 	    warned = warning_at (loc, OPT_Wdeprecated_non_prototype,
+@@ -4307,7 +4336,7 @@ convert_arguments (location_t loc, vec<location_t> arg_loc, tree fntype,
+ 				 " for function %qE declared without parameters",
+ 				 function);
+ 	  if (warned)
+-	    inform_declaration (fundecl);
++	    inform_declaration (fundecl, function);
+ 	}
+ 
+       if (selector && argnum > 2)
+@@ -4437,8 +4466,33 @@ convert_arguments (location_t loc, vec<location_t> arg_loc, tree fntype,
+ 
+   if (typetail != NULL_TREE && TREE_VALUE (typetail) != void_type_node)
+     {
+-      error_at (loc, "too few arguments to function %qE", function);
+-      inform_declaration (fundecl);
++      /* Not enough args.
++	 Determine minimum number of arguments required.  */
++      int min_expected_num = 0;
++      bool at_least_p = false;
++      tree iter = typelist;
++      while (true)
++	{
++	  if (!iter)
++	    {
++	      /* Variadic arguments; stop iterating.  */
++	      at_least_p = true;
++	      break;
++	    }
++	  if (iter == void_list_node)
++	    /* End of arguments; stop iterating.  */
++	    break;
++	  ++min_expected_num;
++	  iter = TREE_CHAIN (iter);
++	}
++      auto_diagnostic_group d;
++      int actual_num = vec_safe_length (values);
++      error_at (loc,
++		at_least_p
++		? G_("too few arguments to function %qE; expected at least %i, have %i")
++		: G_("too few arguments to function %qE; expected %i, have %i"),
++		function, min_expected_num, actual_num);
++      inform_declaration (fundecl, function);
+       return -1;
+     }
+ 
+@@ -4448,10 +4502,11 @@ convert_arguments (location_t loc, vec<location_t> arg_loc, tree fntype,
+       for (tree t = builtin_typetail; t; t = TREE_CHAIN (t))
+ 	++nargs;
+ 
++      auto_diagnostic_group d;
+       if (warning_at (loc, OPT_Wbuiltin_declaration_mismatch,
+ 		      "too few arguments to built-in function %qE "
+ 		      "expecting %u", function, nargs - 1))
+-	inform_declaration (fundecl);
++	inform_declaration (fundecl, function);
+     }
+ 
+   return error_args ? -1 : (int) parmnum;
+diff --git a/gcc/cp/typeck.cc b/gcc/cp/typeck.cc
+index 964e549a6122..2966931ca8c1 100644
+--- a/gcc/cp/typeck.cc
++++ b/gcc/cp/typeck.cc
+@@ -59,7 +59,7 @@ static tree get_delta_difference (tree, tree, bool, bool, tsubst_flags_t);
+ static void casts_away_constness_r (tree *, tree *, tsubst_flags_t);
+ static bool casts_away_constness (tree, tree, tsubst_flags_t);
+ static bool maybe_warn_about_returning_address_of_local (tree, location_t = UNKNOWN_LOCATION);
+-static void error_args_num (location_t, tree, bool);
++static void error_args_num (location_t, tree, int, int, bool);
+ static int convert_arguments (tree, vec<tree, va_gc> **, tree, int,
+                               tsubst_flags_t);
+ static bool is_std_move_p (tree);
+@@ -4533,11 +4533,16 @@ cp_build_function_call_vec (tree function, vec<tree, va_gc> **params,
+ }
+ \f
+ /* Subroutine of convert_arguments.
+-   Print an error message about a wrong number of arguments.  */
++   Print an error message about a wrong number of arguments.
++   If AT_LEAST_P is true, then EXPECTED_NUM is the minimum number
++   of expected arguments.  */
+ 
+ static void
+-error_args_num (location_t loc, tree fndecl, bool too_many_p)
++error_args_num (location_t loc, tree fndecl, int expected_num, int actual_num,
++		bool at_least_p)
+ {
++  gcc_assert (expected_num != actual_num);
++  const bool too_many_p = actual_num > expected_num;
+   if (fndecl)
+     {
+       auto_diagnostic_group d;
+@@ -4548,22 +4553,28 @@ error_args_num (location_t loc, tree fndecl, bool too_many_p)
+ 		  == DECL_NAME (TYPE_NAME (DECL_CONTEXT (fndecl)))))
+ 	    error_at (loc,
+ 		      too_many_p
+-		      ? G_("too many arguments to constructor %q#D")
+-		      : G_("too few arguments to constructor %q#D"),
+-		      fndecl);
++		      ? G_("too many arguments to constructor %q#D; expected %i, have %i")
++		      : (at_least_p
++			 ? G_("too few arguments to constructor %q#D; expected at least %i, have %i")
++			 : G_("too few arguments to constructor %q#D; expected %i, have %i")),
++		      fndecl, expected_num, actual_num);
+ 	  else
+ 	    error_at (loc,
+ 		      too_many_p
+-		      ? G_("too many arguments to member function %q#D")
+-		      : G_("too few arguments to member function %q#D"),
+-		      fndecl);
++		      ? G_("too many arguments to member function %q#D; expected %i, have %i")
++		      : (at_least_p
++			 ? G_("too few arguments to member function %q#D; expected at least %i, have %i")
++			 : G_("too few arguments to member function %q#D; expected %i, have %i")),
++		      fndecl, expected_num, actual_num);
+ 	}
+       else
+ 	error_at (loc,
+ 		  too_many_p
+-		  ? G_("too many arguments to function %q#D")
+-		  : G_("too few arguments to function %q#D"),
+-		  fndecl);
++		  ? G_("too many arguments to function %q#D; expected %i, have %i")
++		  : (at_least_p
++		     ? G_("too few arguments to function %q#D; expected at least %i, have %i")
++		     : G_("too few arguments to function %q#D; expected %i, have %i")),
++		  fndecl, expected_num, actual_num);
+       if (!DECL_IS_UNDECLARED_BUILTIN (fndecl))
+ 	inform (DECL_SOURCE_LOCATION (fndecl), "declared here");
+     }
+@@ -4572,12 +4583,19 @@ error_args_num (location_t loc, tree fndecl, bool too_many_p)
+       if (c_dialect_objc ()  &&  objc_message_selector ())
+ 	error_at (loc,
+ 		  too_many_p
+-		  ? G_("too many arguments to method %q#D")
+-		  : G_("too few arguments to method %q#D"),
+-		  objc_message_selector ());
++		  ? G_("too many arguments to method %q#D; expected %i, have %i")
++		  : (at_least_p
++		     ? G_("too few arguments to method %q#D; expected at least %i, have %i")
++		     : G_("too few arguments to method %q#D; expected %i, have %i")),
++		  objc_message_selector (), expected_num, actual_num);
+       else
+-	error_at (loc, too_many_p ? G_("too many arguments to function")
+-		                  : G_("too few arguments to function"));
++	error_at (loc,
++		  too_many_p
++		  ? G_("too many arguments to function; expected %i, have %i")
++		  : (at_least_p
++		     ? G_("too few arguments to function; expected at least %i, have %i")
++		     : G_("too few arguments to function; expected %i, have %i")),
++		  expected_num, actual_num);
+     }
+ }
+ 
+@@ -4607,6 +4625,10 @@ convert_arguments (tree typelist, vec<tree, va_gc> **values, tree fndecl,
+   /* Argument passing is always copy-initialization.  */
+   flags |= LOOKUP_ONLYCONVERTING;
+ 
++  /* Preserve actual number of arguments passed (without counting default
++     args), in case we need to complain about too many/few.  */
++  int actual_num = vec_safe_length (*values);
++
+   for (i = 0, typetail = typelist;
+        i < vec_safe_length (*values);
+        i++)
+@@ -4621,7 +4643,10 @@ convert_arguments (tree typelist, vec<tree, va_gc> **values, tree fndecl,
+ 	{
+           if (complain & tf_error)
+             {
+-	      error_args_num (input_location, fndecl, /*too_many_p=*/true);
++	      /* Too many args.  */
++	      int expected_num = i;
++	      error_args_num (input_location, fndecl, expected_num, actual_num,
++			      false);
+               return i;
+             }
+           else
+@@ -4743,7 +4768,38 @@ convert_arguments (tree typelist, vec<tree, va_gc> **values, tree fndecl,
+       if (typetail && typetail != void_list_node)
+ 	{
+ 	  if (complain & tf_error)
+-	    error_args_num (input_location, fndecl, /*too_many_p=*/false);
++	    {
++	      /* Not enough args.
++		 Determine minimum number of arguments required.  */
++	      int min_expected_num = 0;
++	      bool at_least_p = false;
++	      tree iter = typelist;
++	      while (true)
++		{
++		  if (!iter)
++		    {
++		      /* Variadic arguments; stop iterating.  */
++		      at_least_p = true;
++		      break;
++		    }
++		  if (iter == void_list_node)
++		    /* End of arguments; stop iterating.  */
++		    break;
++		  if (fndecl && TREE_PURPOSE (iter)
++		      && TREE_CODE (TREE_PURPOSE (iter)) != DEFERRED_PARSE)
++		    {
++		      /* Found a default argument; skip this one when
++			 counting minimum required.  */
++		      at_least_p = true;
++		      iter = TREE_CHAIN (iter);
++		      continue;
++		    }
++		  ++min_expected_num;
++		  iter = TREE_CHAIN (iter);
++		}
++	      error_args_num (input_location, fndecl,
++			      min_expected_num, actual_num, at_least_p);
++	    }
+ 	  return -1;
+ 	}
+     }
+diff --git a/gcc/testsuite/c-c++-common/too-few-arguments.c b/gcc/testsuite/c-c++-common/too-few-arguments.c
+new file mode 100644
+index 000000000000..633dccfeaf24
+--- /dev/null
++++ b/gcc/testsuite/c-c++-common/too-few-arguments.c
+@@ -0,0 +1,38 @@
++extern void fn_a (void);
++extern void fn_b (int); /* { dg-message "declared here" } */
++extern void fn_c (int, int); /* { dg-message "declared here" } */
++#ifdef __cplusplus
++extern void fn_d (int, int=42); /* { dg-message "declared here" "" { target c++ } } */
++extern void fn_e (int, int=42, int=1066); /* { dg-message "declared here" "" { target c++ } } */
++#endif
++extern void fn_f (const char *, ...); /* { dg-message "declared here" } */
++
++void test_known_fn (void)
++{
++  fn_a ();
++  fn_b ();  /* { dg-error "too few arguments to function '\[^\n\r\]*'; expected 1, have 0" } */
++  fn_c (42);/* { dg-error "too few arguments to function '\[^\n\r\]*'; expected 2, have 1" } */
++#ifdef __cplusplus
++  fn_d ();  /* { dg-error "too few arguments to function '\[^\n\r\]*'; expected at least 1, have 0" "" { target c++ } } */
++  fn_e ();  /* { dg-error "too few arguments to function '\[^\n\r\]*'; expected at least 1, have 0" "" { target c++ } } */
++#endif
++  fn_f ();  /* { dg-error "too few arguments to function '\[^\n\r\]*'; expected at least 1, have 0" } */
++}
++
++struct foo
++{
++  void (*callback_a) (void);
++  void (*callback_b) (int); /* { dg-message "declared here" "" { target c } } */
++  void (*callback_c) (int, int); /* { dg-message "declared here" "" { target c } } */
++};
++
++void test_callback (struct foo *f)
++{
++  f->callback_a ();
++  
++  f->callback_b (); /* { dg-error "too few arguments to function 'f->callback_b'; expected 1, have 0" "" { target c } } */
++  /* { dg-error "too few arguments to function; expected 1, have 0" "" { target c++ } .-1 } */
++
++  f->callback_c (42); /* { dg-error "too few arguments to function 'f->callback_c'; expected 2, have 1" "" { target c } } */
++  /* { dg-error "too few arguments to function; expected 2, have 1" "" { target c++ } .-1 } */
++}
+diff --git a/gcc/testsuite/c-c++-common/too-many-arguments.c b/gcc/testsuite/c-c++-common/too-many-arguments.c
+new file mode 100644
+index 000000000000..7f9f8d4870bf
+--- /dev/null
++++ b/gcc/testsuite/c-c++-common/too-many-arguments.c
+@@ -0,0 +1,96 @@
++/* For C, verify that the first excess param is underlined.
++   For C++ the calls location covers all the params, so we
++   can't underline individual params.  */
++/* { dg-additional-options "-fdiagnostics-show-caret" { target c } } */
++
++extern void fn_a (); /* { dg-message "declared here" } */
++extern void fn_b (void); /* { dg-message "declared here" } */
++extern void fn_c (int); /* { dg-message "declared here" } */
++#ifdef __cplusplus
++extern void fn_d (int, int=42); /* { dg-message "declared here" "" { target c++ } } */
++#endif
++
++void test_known_fn (void)
++{
++  fn_a (42); /* { dg-error "too many arguments to function 'fn_a'; expected 0, have 1" "" { target c } } */
++  /* { dg-error "too many arguments to function 'void fn_a\\(\\)'; expected 0, have 1" "" { target c++ } .-1 } */
++  /* { dg-begin-multiline-output "" }
++   fn_a (42);
++   ^~~~  ~~
++     { dg-end-multiline-output "" { target c } } */
++  /* { dg-begin-multiline-output "" }
++ extern void fn_a ();
++             ^~~~
++     { dg-end-multiline-output "" { target c } } */
++
++  fn_b (1776); /* { dg-error "too many arguments to function 'fn_b'; expected 0, have 1" "" { target c } } */
++  /* { dg-error "too many arguments to function 'void fn_b\\(\\)'; expected 0, have 1" "" { target c++ } .-1 } */
++  /* { dg-begin-multiline-output "" }
++   fn_b (1776);
++   ^~~~  ~~~~
++   { dg-end-multiline-output "" { target c } } */
++  /* { dg-begin-multiline-output "" }
++ extern void fn_b (void);
++             ^~~~
++     { dg-end-multiline-output "" { target c } } */
++
++  fn_c (1066, 1649);  /* { dg-error "too many arguments to function 'fn_c'; expected 1, have 2" "" { target c } } */
++  /* { dg-error "too many arguments to function 'void fn_c\\(int\\)'; expected 1, have 2" "" { target c++ } .-1 } */
++  /* { dg-begin-multiline-output "" }
++   fn_c (1066, 1649);
++   ^~~~        ~~~~
++   { dg-end-multiline-output "" { target c } } */
++  /* { dg-begin-multiline-output "" }
++ extern void fn_c (int);
++             ^~~~
++     { dg-end-multiline-output "" { target c } } */
++
++#ifdef __cplusplus
++  fn_d (1066);
++  fn_d (1066, 1649);
++  fn_d (1066, 1649, 1776); /* { dg-error "too many arguments to function '\[^\n\r\]*'; expected 2, have 3" "" { target c++ } } */
++#endif
++}
++
++struct foo
++{
++  void (*callback_a)(); /* { dg-message "declared here" "" { target c } } */
++  void (*callback_b)(void); /* { dg-message "declared here" "" { target c } } */
++  void (*callback_c)(int); /* { dg-message "declared here" "" { target c } } */
++};
++
++void test_callback (struct foo *f)
++{
++  f->callback_a (42); /* { dg-error "too many arguments to function 'f->callback_a'; expected 0, have 1" "" { target c } } */
++  /* { dg-error "too many arguments to function; expected 0, have 1" "" { target c++ } .-1 } */
++  /* { dg-begin-multiline-output "" }
++   f->callback_a (42);
++   ^              ~~
++     { dg-end-multiline-output "" { target c } } */
++  /* { dg-begin-multiline-output "" }
++   void (*callback_a)();
++          ^~~~~~~~~~
++     { dg-end-multiline-output "" { target c } } */
++  
++  f->callback_b (1776); /* { dg-error "too many arguments to function 'f->callback_b'; expected 0, have 1" "" { target c } } */
++  /* { dg-error "too many arguments to function; expected 0, have 1" "" { target c++ } .-1 } */
++  /* { dg-begin-multiline-output "" }
++   f->callback_b (1776);
++   ^              ~~~~
++     { dg-end-multiline-output "" { target c } } */
++  /* { dg-begin-multiline-output "" }
++   void (*callback_b)(void);
++          ^~~~~~~~~~
++     { dg-end-multiline-output "" { target c } } */
++
++  f->callback_c (1066, 1649); /* { dg-error "too many arguments to function 'f->callback_c'; expected 1, have 2" "" { target c } } */
++  /* { dg-error "too many arguments to function; expected 1, have 2" "" { target c++ } .-1 } */
++  /* { dg-begin-multiline-output "" }
++   f->callback_c (1066, 1649);
++   ^                    ~~~~
++     { dg-end-multiline-output "" { target c } } */
++  /* { dg-begin-multiline-output "" }
++   void (*callback_c)(int);
++          ^~~~~~~~~~
++     { dg-end-multiline-output "" { target c } } */
++}
+diff --git a/gcc/testsuite/g++.dg/cpp0x/variadic169.C b/gcc/testsuite/g++.dg/cpp0x/variadic169.C
+index 6858973cd2eb..460bb3b8a193 100644
+--- a/gcc/testsuite/g++.dg/cpp0x/variadic169.C
++++ b/gcc/testsuite/g++.dg/cpp0x/variadic169.C
+@@ -5,5 +5,5 @@ template<typename ...T> void f(int n = 0, T ...t);
+ 
+ int main()
+ {
+-  f<int>();			// { dg-error "too few arguments" }
++  f<int>();			// { dg-error "too few arguments to function '\[^\n\r\]*'; expected at least 1, have 0" }
+ }
+diff --git a/gcc/testsuite/g++.dg/modules/macloc-1_c.C b/gcc/testsuite/g++.dg/modules/macloc-1_c.C
+index 5865a34687e7..3f980c213814 100644
+--- a/gcc/testsuite/g++.dg/modules/macloc-1_c.C
++++ b/gcc/testsuite/g++.dg/modules/macloc-1_c.C
+@@ -8,6 +8,6 @@ void gru ()
+   you (1);
+ }
+ 
+-// { dg-regexp "\[^\n]*macloc-1_c.C:7:6: error: too many arguments to function 'int me@agnes\\(\\)'\nIn module agnes, imported at \[^\n]*macloc-1_b.C:8,\nof module edith, imported at \[^\n]*macloc-1_c.C:3:\n\[^\n]*macloc-1_a.C:11:12: note: declared here\n\[^\n]*macloc-1_a.C:8:20: note: in definition of macro 'BOB'\n" }
++// { dg-regexp "\[^\n]*macloc-1_c.C:7:6: error: too many arguments to function 'int me@agnes\\(\\)'; expected 0, have 1\nIn module agnes, imported at \[^\n]*macloc-1_b.C:8,\nof module edith, imported at \[^\n]*macloc-1_c.C:3:\n\[^\n]*macloc-1_a.C:11:12: note: declared here\n\[^\n]*macloc-1_a.C:8:20: note: in definition of macro 'BOB'\n" }
+ 
+-// { dg-regexp "\[^\n]*macloc-1_c.C:8:7: error: too many arguments to function 'int you@agnes\\(\\)'\nIn module agnes, imported at \[^\n]*macloc-1_b.C:8,\nof module edith, imported at \[^\n]*macloc-1_c.C:3:\n\[^\n]*macloc-1_a.C:12:14: note: declared here\n\[^\n]*macloc-1_a.C:9:22: note: in definition of macro 'KEVIN'\n" }
++// { dg-regexp "\[^\n]*macloc-1_c.C:8:7: error: too many arguments to function 'int you@agnes\\(\\)'; expected 0, have 1\nIn module agnes, imported at \[^\n]*macloc-1_b.C:8,\nof module edith, imported at \[^\n]*macloc-1_c.C:3:\n\[^\n]*macloc-1_a.C:12:14: note: declared here\n\[^\n]*macloc-1_a.C:9:22: note: in definition of macro 'KEVIN'\n" }
+diff --git a/gcc/testsuite/g++.dg/modules/macloc-1_d.C b/gcc/testsuite/g++.dg/modules/macloc-1_d.C
+index 282a31c4a2d1..56c001fc3f83 100644
+--- a/gcc/testsuite/g++.dg/modules/macloc-1_d.C
++++ b/gcc/testsuite/g++.dg/modules/macloc-1_d.C
+@@ -9,5 +9,5 @@ void margo ()
+   gru (2);
+ }
+ 
+-// { dg-regexp "\[^\n]*macloc-1_d.C:8:6: error: too many arguments to function 'int me@agnes\\(\\)'\nIn module agnes, imported at \[^\n]*macloc-1_d.C:4:\n\[^\n]*macloc-1_a.C:11:12: note: declared here\n\[^\n]*macloc-1_a.C:8:20: note: in definition of macro 'BOB'\n" }
+-// { dg-regexp "\[^\n]*macloc-1_d.C:9:7: error: too many arguments to function 'void gru@edith\\(\\)'\nIn module edith, imported at \[^\n]*macloc-1_d.C:3:\n\[^\n]*macloc-1_b.C:10:20: note: declared here\n\[^\n]*macloc-1_b.C:6:19: note: in definition of macro 'STUART'\n" }
++// { dg-regexp "\[^\n]*macloc-1_d.C:8:6: error: too many arguments to function 'int me@agnes\\(\\)'; expected 0, have 1\nIn module agnes, imported at \[^\n]*macloc-1_d.C:4:\n\[^\n]*macloc-1_a.C:11:12: note: declared here\n\[^\n]*macloc-1_a.C:8:20: note: in definition of macro 'BOB'\n" }
++// { dg-regexp "\[^\n]*macloc-1_d.C:9:7: error: too many arguments to function 'void gru@edith\\(\\)'; expected 0, have 1\nIn module edith, imported at \[^\n]*macloc-1_d.C:3:\n\[^\n]*macloc-1_b.C:10:20: note: declared here\n\[^\n]*macloc-1_b.C:6:19: note: in definition of macro 'STUART'\n" }
+
+base-commit: b11e85adbfdb02bc7743098d358a5ea362648ca1
+-- 
+2.47.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index e2217e1..515a20d 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,8 @@
+33	????
+
+	- 77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
+	+ 77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
+
 32	16 December 2024
 
 	- 72_all_PR111600-genrecog-Split-into-separate-partitions.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-20  5:57 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-20  5:57 UTC (permalink / raw
  To: gentoo-commits
commit:     8c4b3ec7d2a3a535646648d05bcaa6706cc0f695
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 20 05:57:00 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Dec 20 05:57:00 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=8c4b3ec7
15.0.0: revert patch causing (riscv) bootstrap slowdown
Bug: https://gcc.gnu.org/PR118032
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...le-Add-limit-after-which-slower-switchlow.patch | 238 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 239 insertions(+)
diff --git a/15.0.0/gentoo/78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch b/15.0.0/gentoo/78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch
new file mode 100644
index 0000000..d7f2c46
--- /dev/null
+++ b/15.0.0/gentoo/78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch
@@ -0,0 +1,238 @@
+From 7305d9452ae9bfc3ee299a194b103e4a4786b0ee Mon Sep 17 00:00:00 2001
+Message-ID: <7305d9452ae9bfc3ee299a194b103e4a4786b0ee.1734674183.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Fri, 20 Dec 2024 05:56:03 +0000
+Subject: [PATCH] Revert "gimple: Add limit after which slower switchlower algs
+ are used [PR117091] [PR117352]"
+
+This reverts commit 56946c801a7cf3a831a11870b7e11ba08bf9bd87.
+
+Bug: https://gcc.gnu.org/PR118032
+---
+ gcc/doc/invoke.texi           |   3 -
+ gcc/params.opt                |   4 --
+ gcc/tree-switch-conversion.cc | 112 +++-------------------------------
+ gcc/tree-switch-conversion.h  |  18 ------
+ 4 files changed, 7 insertions(+), 130 deletions(-)
+
+diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
+index 8ed5536365f7..08ad6b998b79 100644
+--- a/gcc/doc/invoke.texi
++++ b/gcc/doc/invoke.texi
+@@ -16522,9 +16522,6 @@ Switch initialization conversion refuses to create arrays that are
+ bigger than @option{switch-conversion-max-branch-ratio} times the number of
+ branches in the switch.
+ 
+-@item switch-lower-slow-alg-max-cases
+-Maximum number of cases for slow switch lowering algorithms to be used.
+-
+ @item max-partial-antic-length
+ Maximum length of the partial antic set computed during the tree
+ partial redundancy elimination optimization (@option{-ftree-pre}) when
+diff --git a/gcc/params.opt b/gcc/params.opt
+index 1c88d5212c40..5853bf02f9ee 100644
+--- a/gcc/params.opt
++++ b/gcc/params.opt
+@@ -1052,10 +1052,6 @@ Maximum number of instruction distance that a small store forwarded to a larger
+ Common Joined UInteger Var(param_switch_conversion_branch_ratio) Init(8) IntegerRange(1, 65536) Param Optimization
+ The maximum ratio between array size and switch branches for a switch conversion to take place.
+ 
+--param=switch-lower-slow-alg-max-cases=
+-Common Joined UInteger Var(param_switch_lower_slow_alg_max_cases) Init(1000) IntegerRange(1, 1000000000) Param Optimization
+-Maximum number of cases for slow switch lowering algorithms to be used.
+-
+ -param=modref-max-bases=
+ Common Joined UInteger Var(param_modref_max_bases) Init(32) Param Optimization
+ Maximum number of bases stored in each modref tree.
+diff --git a/gcc/tree-switch-conversion.cc b/gcc/tree-switch-conversion.cc
+index b98e70cf7d16..3436c2a8b98c 100644
+--- a/gcc/tree-switch-conversion.cc
++++ b/gcc/tree-switch-conversion.cc
+@@ -54,7 +54,6 @@ Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
+ #include "tree-cfgcleanup.h"
+ #include "hwint.h"
+ #include "internal-fn.h"
+-#include "diagnostic-core.h"
+ 
+ /* ??? For lang_hooks.types.type_for_mode, but is there a word_mode
+    type in the GIMPLE type system that is language-independent?  */
+@@ -1642,11 +1641,6 @@ jump_table_cluster::find_jump_tables (vec<cluster *> &clusters)
+     return clusters.copy ();
+ 
+   unsigned l = clusters.length ();
+-
+-  /* Note: l + 1 is the number of cases of the switch.  */
+-  if (l + 1 > (unsigned) param_switch_lower_slow_alg_max_cases)
+-    return clusters.copy ();
+-
+   auto_vec<min_cluster_item> min;
+   min.reserve (l + 1);
+ 
+@@ -1777,80 +1771,16 @@ jump_table_cluster::is_beneficial (const vec<cluster *> &,
+   return end - start + 1 >= case_values_threshold ();
+ }
+ 
+-/* Find bit tests of given CLUSTERS, where all members of the vector are of
+-   type simple_cluster.  Use a fast algorithm that might not find the optimal
+-   solution (minimal number of clusters on the output).  New clusters are
+-   returned.
+-
+-   You should call find_bit_tests () instead of calling this function
+-   directly.  */
+-
+-vec<cluster *>
+-bit_test_cluster::find_bit_tests_fast (vec<cluster *> &clusters)
+-{
+-  unsigned l = clusters.length ();
+-  vec<cluster *> output;
+-
+-  output.create (l);
+-
+-  /* Look at sliding BITS_PER_WORD sized windows in the switch value space
+-     and determine if they are suitable for a bit test cluster.  Worst case
+-     this can examine every value BITS_PER_WORD-1 times.  */
+-  unsigned k;
+-  for (unsigned i = 0; i < l; i += k)
+-    {
+-      hash_set<basic_block> targets;
+-      cluster *start_cluster = clusters[i];
+-
+-      /* Find the biggest k such that clusters i to i+k-1 can be turned into a
+-	 one big bit test cluster.  */
+-      k = 0;
+-      while (i + k < l)
+-	{
+-	  cluster *end_cluster = clusters[i + k];
+-
+-	  /* Does value range fit into the BITS_PER_WORD window?  */
+-	  HOST_WIDE_INT w = cluster::get_range (start_cluster->get_low (),
+-						end_cluster->get_high ());
+-	  if (w == 0 || w > BITS_PER_WORD)
+-	    break;
+-
+-	  /* Check for max # of targets.  */
+-	  if (targets.elements () == m_max_case_bit_tests
+-	      && !targets.contains (end_cluster->m_case_bb))
+-	    break;
+-
+-	  targets.add (end_cluster->m_case_bb);
+-	  k++;
+-	}
+-
+-      if (is_beneficial (k, targets.elements ()))
+-	{
+-	  output.safe_push (new bit_test_cluster (clusters, i, i + k - 1,
+-						  i == 0 && k == l));
+-	}
+-      else
+-	{
+-	  output.safe_push (clusters[i]);
+-	  /* ??? Might be able to skip more.  */
+-	  k = 1;
+-	}
+-    }
+-
+-  return output;
+-}
+-
+ /* Find bit tests of given CLUSTERS, where all members of the vector
+-   are of type simple_cluster.  Use a slow (quadratic) algorithm that always
+-   finds the optimal solution (minimal number of clusters on the output).  New
+-   clusters are returned.
+-
+-   You should call find_bit_tests () instead of calling this function
+-   directly.  */
++   are of type simple_cluster.   MAX_C is the approx max number of cases per
++   label.  New clusters are returned.  */
+ 
+ vec<cluster *>
+-bit_test_cluster::find_bit_tests_slow (vec<cluster *> &clusters)
++bit_test_cluster::find_bit_tests (vec<cluster *> &clusters, int max_c)
+ {
++  if (!is_enabled () || max_c == 1)
++    return clusters.copy ();
++
+   unsigned l = clusters.length ();
+   auto_vec<min_cluster_item> min;
+   min.reserve (l + 1);
+@@ -1904,25 +1834,6 @@ bit_test_cluster::find_bit_tests_slow (vec<cluster *> &clusters)
+   return output;
+ }
+ 
+-/* Find bit tests of given CLUSTERS, where all members of the vector
+-   are of type simple_cluster.  MAX_C is the approx max number of cases per
+-   label.  New clusters are returned.  */
+-
+-vec<cluster *>
+-bit_test_cluster::find_bit_tests (vec<cluster *> &clusters, int max_c)
+-{
+-  if (!is_enabled () || max_c == 1)
+-    return clusters.copy ();
+-
+-  unsigned l = clusters.length ();
+-
+-  /* Note: l + 1 is the number of cases of the switch.  */
+-  if (l + 1 > (unsigned) param_switch_lower_slow_alg_max_cases)
+-    return find_bit_tests_fast (clusters);
+-  else
+-    return find_bit_tests_slow (clusters);
+-}
+-
+ /* Return true when RANGE of case values with UNIQ labels
+    can build a bit test.  */
+ 
+@@ -2353,19 +2264,10 @@ switch_decision_tree::analyze_switch_statement ()
+ 
+   reset_out_edges_aux (m_switch);
+ 
+-  if (l > (unsigned) param_switch_lower_slow_alg_max_cases)
+-    warning_at (gimple_location (m_switch), OPT_Wdisabled_optimization,
+-	       "Using faster switch lowering algorithms. "
+-	       "Number of switch cases (%d) exceeds "
+-	       "%<--param=switch-lower-slow-alg-max-cases=%d%> limit.",
+-	       l, param_switch_lower_slow_alg_max_cases);
+-
+   /* Find bit-test clusters.  */
+   vec<cluster *> output = bit_test_cluster::find_bit_tests (clusters, max_c);
+ 
+-  /* Find jump table clusters.  We are looking for these in the sequences of
+-     simple clusters which we didn't manage to convert into bit-test
+-     clusters.  */
++  /* Find jump table clusters.  */
+   vec<cluster *> output2;
+   auto_vec<cluster *> tmp;
+   output2.create (1);
+diff --git a/gcc/tree-switch-conversion.h b/gcc/tree-switch-conversion.h
+index 560620903a86..e6a85fa60258 100644
+--- a/gcc/tree-switch-conversion.h
++++ b/gcc/tree-switch-conversion.h
+@@ -397,24 +397,6 @@ public:
+ 	     tree default_label_expr, basic_block default_bb, location_t loc)
+      final override;
+ 
+-  /* Find bit tests of given CLUSTERS, where all members of the vector are of
+-     type simple_cluster.  Use a fast algorithm that might not find the optimal
+-     solution (minimal number of clusters on the output).  New clusters are
+-     returned.
+-
+-     You should call find_bit_tests () instead of calling this function
+-     directly.  */
+-  static vec<cluster *> find_bit_tests_fast (vec<cluster *> &clusters);
+-
+-  /* Find bit tests of given CLUSTERS, where all members of the vector
+-     are of type simple_cluster.  Use a slow (quadratic) algorithm that always
+-     finds the optimal solution (minimal number of clusters on the output).  New
+-     clusters are returned.
+-
+-     You should call find_bit_tests () instead of calling this function
+-     directly.  */
+-  static vec<cluster *> find_bit_tests_slow (vec<cluster *> &clusters);
+-
+   /* Find bit tests of given CLUSTERS, where all members of the vector
+      are of type simple_cluster.  New clusters are returned.  */
+   static vec<cluster *> find_bit_tests (vec<cluster *> &clusters, int max_c);
+
+base-commit: b11e85adbfdb02bc7743098d358a5ea362648ca1
+-- 
+2.47.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 515a20d..dcaecc1 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -2,6 +2,7 @@
 
 	- 77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
 	+ 77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
+	+ 78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch
 
 32	16 December 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-20 11:25 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-20 11:25 UTC (permalink / raw
  To: gentoo-commits
commit:     01d33f6be28d09edb2e9aaa66feab7a1b359aa60
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 20 11:24:56 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Dec 20 11:25:19 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=01d33f6b
15.0.0: fix C++ init ICE
Bug: https://gcc.gnu.org/PR118124
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...Es-with-large-initializer-lists-or-ones-i.patch | 307 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 308 insertions(+)
diff --git a/15.0.0/gentoo/79_all_PR118124-c-Fix-ICEs-with-large-initializer-lists-or-ones-i.patch b/15.0.0/gentoo/79_all_PR118124-c-Fix-ICEs-with-large-initializer-lists-or-ones-i.patch
new file mode 100644
index 0000000..ded69c7
--- /dev/null
+++ b/15.0.0/gentoo/79_all_PR118124-c-Fix-ICEs-with-large-initializer-lists-or-ones-i.patch
@@ -0,0 +1,307 @@
+https://inbox.sourceware.org/gcc-patches/Z2U3spZjDr+xEZP0@tucnak/
+
+From b904875837cae597709d37ec45f70c70d353e901 Mon Sep 17 00:00:00 2001
+Message-ID: <b904875837cae597709d37ec45f70c70d353e901.1734693860.git.sam@gentoo.org>
+From: Jakub Jelinek <jakub@redhat.com>
+Date: Fri, 20 Dec 2024 10:24:02 +0100
+Subject: [PATCH] c++, v3: Fix ICEs with large initializer lists or ones
+ including #embed [PR118124]
+
+On Thu, Dec 19, 2024 at 07:01:39PM +0100, Jakub Jelinek wrote:
+> So far lightly tested, ok for trunk this way if it passes bootstrap & testing?
+
+Bootstrap/regtest found an issue, warning about
+  if ()
+    for ()
+      if ()
+      else if ()
+      else
+so I've added {}s around it (no other changes from the previous patch).
+
+Bootstrapped/regtested on x86_64-linux and i686-linux, ok for trunk?
+
+2024-12-20  Jakub Jelinek  <jakub@redhat.com>
+
+	PR c++/118124
+	* call.cc (convert_like_internal): Handle RAW_DATA_CST in
+	ck_list handling.  Formatting fixes.
+
+	* g++.dg/cpp/embed-15.C: New test.
+	* g++.dg/cpp/embed-16.C: New test.
+	* g++.dg/cpp0x/initlist-opt3.C: New test.
+	* g++.dg/cpp0x/initlist-opt4.C: New test.
+---
+ gcc/cp/call.cc                             | 84 ++++++++++++++++++++--
+ gcc/testsuite/g++.dg/cpp/embed-15.C        | 35 +++++++++
+ gcc/testsuite/g++.dg/cpp/embed-16.C        | 18 +++++
+ gcc/testsuite/g++.dg/cpp0x/initlist-opt3.C | 47 ++++++++++++
+ gcc/testsuite/g++.dg/cpp0x/initlist-opt4.C | 20 ++++++
+ 5 files changed, 198 insertions(+), 6 deletions(-)
+ create mode 100644 gcc/testsuite/g++.dg/cpp/embed-15.C
+ create mode 100644 gcc/testsuite/g++.dg/cpp/embed-16.C
+ create mode 100644 gcc/testsuite/g++.dg/cpp0x/initlist-opt3.C
+ create mode 100644 gcc/testsuite/g++.dg/cpp0x/initlist-opt4.C
+
+diff --git a/gcc/cp/call.cc b/gcc/cp/call.cc
+index c8420db568ea..27cea0db80af 100644
+--- a/gcc/cp/call.cc
++++ b/gcc/cp/call.cc
+@@ -8766,8 +8766,8 @@ convert_like_internal (conversion *convs, tree expr, tree fn, int argnum,
+ 
+ 	if (tree init = maybe_init_list_as_array (elttype, expr))
+ 	  {
+-	    elttype = cp_build_qualified_type
+-	      (elttype, cp_type_quals (elttype) | TYPE_QUAL_CONST);
++	    elttype = cp_build_qualified_type (elttype, cp_type_quals (elttype)
++							| TYPE_QUAL_CONST);
+ 	    array = build_array_of_n_type (elttype, len);
+ 	    array = build_vec_init_expr (array, init, complain);
+ 	    array = get_target_expr (array);
+@@ -8775,13 +8775,85 @@ convert_like_internal (conversion *convs, tree expr, tree fn, int argnum,
+ 	  }
+ 	else if (len)
+ 	  {
+-	    tree val; unsigned ix;
+-
++	    tree val;
++	    unsigned ix;
+ 	    tree new_ctor = build_constructor (init_list_type_node, NULL);
+ 
+ 	    /* Convert all the elements.  */
+ 	    FOR_EACH_CONSTRUCTOR_VALUE (CONSTRUCTOR_ELTS (expr), ix, val)
+ 	      {
++		if (TREE_CODE (val) == RAW_DATA_CST)
++		  {
++		    tree elt_type;
++		    conversion *next;
++		    /* For conversion to initializer_list<unsigned char> or
++		       initializer_list<char> or initializer_list<signed char>
++		       we can optimize and keep RAW_DATA_CST with adjusted
++		       type if we report narrowing errors if needed, for
++		       others this converts each element separately.  */
++		    if (convs->u.list[ix]->kind == ck_std
++			&& (elt_type = convs->u.list[ix]->type)
++			&& (TREE_CODE (elt_type) == INTEGER_TYPE
++			    || is_byte_access_type (elt_type))
++			&& TYPE_PRECISION (elt_type) == CHAR_BIT
++			&& (next = next_conversion (convs->u.list[ix]))
++			&& next->kind == ck_identity)
++		      {
++			if (!TYPE_UNSIGNED (elt_type)
++			    && (TYPE_UNSIGNED (TREE_TYPE (val))
++				|| (TYPE_PRECISION (TREE_TYPE (val))
++				    > CHAR_BIT)))
++			  for (int i = 0; i < RAW_DATA_LENGTH (val); ++i)
++			    {
++			      if (RAW_DATA_SCHAR_ELT (val, i) >= 0)
++				continue;
++			      else if (complain & tf_error)
++				{
++				  location_t loc
++				    = cp_expr_loc_or_input_loc (val);
++				  int savederrorcount = errorcount;
++				  permerror_opt (loc, OPT_Wnarrowing,
++						 "narrowing conversion of "
++						 "%qd from %qH to %qI",
++						 RAW_DATA_UCHAR_ELT (val, i),
++						 TREE_TYPE (val), elt_type);
++				  if (errorcount != savederrorcount)
++				    return error_mark_node;
++				}
++			      else
++				return error_mark_node;
++			    }
++			tree sub = copy_node (val);
++			TREE_TYPE (sub) = elt_type;
++			CONSTRUCTOR_APPEND_ELT (CONSTRUCTOR_ELTS (new_ctor),
++						NULL_TREE, sub);
++		      }
++		    else
++		      {
++			for (int i = 0; i < RAW_DATA_LENGTH (val); ++i)
++			  {
++			    tree elt
++			      = build_int_cst (TREE_TYPE (val),
++					       RAW_DATA_UCHAR_ELT (val, i));
++			    tree sub
++			      = convert_like (convs->u.list[ix], elt,
++					      fn, argnum, false, false,
++					      /*nested_p=*/true, complain);
++			    if (sub == error_mark_node)
++			      return sub;
++			    if (!check_narrowing (TREE_TYPE (sub), elt,
++						  complain))
++			      return error_mark_node;
++			    tree nc = new_ctor;
++			    CONSTRUCTOR_APPEND_ELT (CONSTRUCTOR_ELTS (nc),
++						    NULL_TREE, sub);
++			    if (!TREE_CONSTANT (sub))
++			      TREE_CONSTANT (new_ctor) = false;
++			  }
++		      }
++		    len += RAW_DATA_LENGTH (val) - 1;
++		    continue;
++		  }
+ 		tree sub = convert_like (convs->u.list[ix], val, fn,
+ 					 argnum, false, false,
+ 					 /*nested_p=*/true, complain);
+@@ -8796,8 +8868,8 @@ convert_like_internal (conversion *convs, tree expr, tree fn, int argnum,
+ 		  TREE_CONSTANT (new_ctor) = false;
+ 	      }
+ 	    /* Build up the array.  */
+-	    elttype = cp_build_qualified_type
+-	      (elttype, cp_type_quals (elttype) | TYPE_QUAL_CONST);
++	    elttype = cp_build_qualified_type (elttype, cp_type_quals (elttype)
++							| TYPE_QUAL_CONST);
+ 	    array = build_array_of_n_type (elttype, len);
+ 	    array = finish_compound_literal (array, new_ctor, complain);
+ 	    /* This is dubious now, should be blessed by P2752.  */
+diff --git a/gcc/testsuite/g++.dg/cpp/embed-15.C b/gcc/testsuite/g++.dg/cpp/embed-15.C
+new file mode 100644
+index 000000000000..a3994536e576
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/cpp/embed-15.C
+@@ -0,0 +1,35 @@
++// PR c++/118124
++// { dg-do compile { target c++11 } }
++// { dg-options "-O2" }
++
++namespace std {
++template <class T> struct initializer_list {
++private:
++  const T *_M_array;
++  __SIZE_TYPE__ _M_len;
++};
++}
++struct A {
++  A (std::initializer_list<char>);
++};
++A a {
++#embed __FILE__
++};
++struct B {
++  B (std::initializer_list<unsigned char>);
++};
++B b {
++#embed __FILE__
++};
++struct C {
++  C (std::initializer_list<int>);
++};
++C c {
++#embed __FILE__
++};
++struct D {
++  D (std::initializer_list<float>);
++};
++D d {
++#embed __FILE__
++};
+diff --git a/gcc/testsuite/g++.dg/cpp/embed-16.C b/gcc/testsuite/g++.dg/cpp/embed-16.C
+new file mode 100644
+index 000000000000..868dce2f165c
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/cpp/embed-16.C
+@@ -0,0 +1,18 @@
++// PR c++/118124
++// { dg-do compile { target c++11 } }
++// { dg-options "-O2" }
++// non-ASCII chars here: áéí
++
++namespace std {
++template <class T> struct initializer_list {
++private:
++  const T *_M_array;
++  __SIZE_TYPE__ _M_len;
++};
++}
++struct A {
++  A (std::initializer_list<signed char>);
++};
++A a {
++#embed __FILE__
++};	// { dg-error "narrowing conversion of '\[0-9]*' from 'int' to 'signed char'" }
+diff --git a/gcc/testsuite/g++.dg/cpp0x/initlist-opt3.C b/gcc/testsuite/g++.dg/cpp0x/initlist-opt3.C
+new file mode 100644
+index 000000000000..fa279882322d
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/cpp0x/initlist-opt3.C
+@@ -0,0 +1,47 @@
++// PR c++/118124
++// { dg-do compile { target c++11 } }
++// { dg-options "-O2" }
++
++namespace std {
++template <class T> struct initializer_list {
++private:
++  const T *_M_array;
++  __SIZE_TYPE__ _M_len;
++};
++}
++struct A {
++  A (std::initializer_list<char>);
++};
++A a { 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7,
++      8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
++      0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1,
++      2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3,
++      4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5,
++      6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5 };
++struct B {
++  B (std::initializer_list<unsigned char>);
++};
++B b { 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7,
++      8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
++      0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1,
++      2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3,
++      4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5,
++      6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5 };
++struct C {
++  C (std::initializer_list<int>);
++};
++C c { 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7,
++      8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
++      0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1,
++      2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3,
++      4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5,
++      6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5 };
++struct D {
++  D (std::initializer_list<float>);
++};
++D d { 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7,
++      8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
++      0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1,
++      2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3,
++      4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5,
++      6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5 };
+diff --git a/gcc/testsuite/g++.dg/cpp0x/initlist-opt4.C b/gcc/testsuite/g++.dg/cpp0x/initlist-opt4.C
+new file mode 100644
+index 000000000000..080dee3cf026
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/cpp0x/initlist-opt4.C
+@@ -0,0 +1,20 @@
++// PR c++/118124
++// { dg-do compile { target c++11 } }
++// { dg-options "-O2" }
++
++namespace std {
++template <class T> struct initializer_list {
++private:
++  const T *_M_array;
++  __SIZE_TYPE__ _M_len;
++};
++}
++struct A {
++  A (std::initializer_list<signed char>);
++};
++A a { 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7,
++      8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
++      0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1,
++      2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 209, 0, 1, 2, 3,
++      4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5,
++      6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5 };	// { dg-error "narrowing conversion of '209' from 'int' to 'signed char'" }
+
+base-commit: 670df03e5294a31efff1554c9a751ef893dc1f71
+-- 
+2.47.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index dcaecc1..425231d 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -3,6 +3,7 @@
 	- 77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
 	+ 77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
 	+ 78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch
+	+ 79_all_PR118124-c-Fix-ICEs-with-large-initializer-lists-or-ones-i.patch
 
 32	16 December 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-22 22:46 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-22 22:46 UTC (permalink / raw
  To: gentoo-commits
commit:     f7b94345a666909bdf29bdd73e9e35b362cc9f5e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 22 22:45:31 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec 22 22:45:31 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=f7b94345
15.0.0: cut patchset 33
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 425231d..95dd852 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-33	????
+33	22 December 2024
 
 	- 77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
 	+ 77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-24 20:48 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-24 20:48 UTC (permalink / raw
  To: gentoo-commits
commit:     afe723f516bec463e75e08da80cf1b8b093336c7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 24 20:47:40 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Dec 24 20:47:56 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=afe723f5
15.0.0: update bashisms patch
Bug: https://bugs.gentoo.org/945296
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch | 2 +-
 15.0.0/gentoo/README.history                                          | 4 ++++
 2 files changed, 5 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/76_all_PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch b/15.0.0/gentoo/76_all_PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch
index 6011313..263204e 100644
--- a/15.0.0/gentoo/76_all_PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch
+++ b/15.0.0/gentoo/76_all_PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch
@@ -34,7 +34,7 @@ index d0a86acb832c..b140de0eb76d 100644
  # <http://www.gnu.org/licenses/>.
  
 -style="$1"
-+style="${1:-${NVPTX_GEN_COPYRIGHT}}"
++style="${NVPTX_GEN_COPYRIGHT}"
  case $style in
      opt)
      ;;
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 95dd852..69a95ed 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+34	24 December 2024
+
+	U 76_all_PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch
+
 33	22 December 2024
 
 	- 77_all_PR117980-ICE-cxx_eval_outermost_constant_expr.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-27 15:14 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-27 15:14 UTC (permalink / raw
  To: gentoo-commits
commit:     8043ac03bbd26d81e5476ed85b8e19b00e5cfc47
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 27 15:13:58 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Dec 27 15:13:58 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=8043ac03
15.0.0: drop 79_all_PR118124-c-Fix-ICEs-with-large-initializer-lists-or-ones-i.patch
The C++ optimisation has been reverted for now upstream so this patch
isn't needed, see https://gcc.gnu.org/bugzilla/show_bug.cgi?id=118124#c4.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...Es-with-large-initializer-lists-or-ones-i.patch | 307 ---------------------
 1 file changed, 307 deletions(-)
diff --git a/15.0.0/gentoo/79_all_PR118124-c-Fix-ICEs-with-large-initializer-lists-or-ones-i.patch b/15.0.0/gentoo/79_all_PR118124-c-Fix-ICEs-with-large-initializer-lists-or-ones-i.patch
deleted file mode 100644
index ded69c7..0000000
--- a/15.0.0/gentoo/79_all_PR118124-c-Fix-ICEs-with-large-initializer-lists-or-ones-i.patch
+++ /dev/null
@@ -1,307 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/Z2U3spZjDr+xEZP0@tucnak/
-
-From b904875837cae597709d37ec45f70c70d353e901 Mon Sep 17 00:00:00 2001
-Message-ID: <b904875837cae597709d37ec45f70c70d353e901.1734693860.git.sam@gentoo.org>
-From: Jakub Jelinek <jakub@redhat.com>
-Date: Fri, 20 Dec 2024 10:24:02 +0100
-Subject: [PATCH] c++, v3: Fix ICEs with large initializer lists or ones
- including #embed [PR118124]
-
-On Thu, Dec 19, 2024 at 07:01:39PM +0100, Jakub Jelinek wrote:
-> So far lightly tested, ok for trunk this way if it passes bootstrap & testing?
-
-Bootstrap/regtest found an issue, warning about
-  if ()
-    for ()
-      if ()
-      else if ()
-      else
-so I've added {}s around it (no other changes from the previous patch).
-
-Bootstrapped/regtested on x86_64-linux and i686-linux, ok for trunk?
-
-2024-12-20  Jakub Jelinek  <jakub@redhat.com>
-
-	PR c++/118124
-	* call.cc (convert_like_internal): Handle RAW_DATA_CST in
-	ck_list handling.  Formatting fixes.
-
-	* g++.dg/cpp/embed-15.C: New test.
-	* g++.dg/cpp/embed-16.C: New test.
-	* g++.dg/cpp0x/initlist-opt3.C: New test.
-	* g++.dg/cpp0x/initlist-opt4.C: New test.
----
- gcc/cp/call.cc                             | 84 ++++++++++++++++++++--
- gcc/testsuite/g++.dg/cpp/embed-15.C        | 35 +++++++++
- gcc/testsuite/g++.dg/cpp/embed-16.C        | 18 +++++
- gcc/testsuite/g++.dg/cpp0x/initlist-opt3.C | 47 ++++++++++++
- gcc/testsuite/g++.dg/cpp0x/initlist-opt4.C | 20 ++++++
- 5 files changed, 198 insertions(+), 6 deletions(-)
- create mode 100644 gcc/testsuite/g++.dg/cpp/embed-15.C
- create mode 100644 gcc/testsuite/g++.dg/cpp/embed-16.C
- create mode 100644 gcc/testsuite/g++.dg/cpp0x/initlist-opt3.C
- create mode 100644 gcc/testsuite/g++.dg/cpp0x/initlist-opt4.C
-
-diff --git a/gcc/cp/call.cc b/gcc/cp/call.cc
-index c8420db568ea..27cea0db80af 100644
---- a/gcc/cp/call.cc
-+++ b/gcc/cp/call.cc
-@@ -8766,8 +8766,8 @@ convert_like_internal (conversion *convs, tree expr, tree fn, int argnum,
- 
- 	if (tree init = maybe_init_list_as_array (elttype, expr))
- 	  {
--	    elttype = cp_build_qualified_type
--	      (elttype, cp_type_quals (elttype) | TYPE_QUAL_CONST);
-+	    elttype = cp_build_qualified_type (elttype, cp_type_quals (elttype)
-+							| TYPE_QUAL_CONST);
- 	    array = build_array_of_n_type (elttype, len);
- 	    array = build_vec_init_expr (array, init, complain);
- 	    array = get_target_expr (array);
-@@ -8775,13 +8775,85 @@ convert_like_internal (conversion *convs, tree expr, tree fn, int argnum,
- 	  }
- 	else if (len)
- 	  {
--	    tree val; unsigned ix;
--
-+	    tree val;
-+	    unsigned ix;
- 	    tree new_ctor = build_constructor (init_list_type_node, NULL);
- 
- 	    /* Convert all the elements.  */
- 	    FOR_EACH_CONSTRUCTOR_VALUE (CONSTRUCTOR_ELTS (expr), ix, val)
- 	      {
-+		if (TREE_CODE (val) == RAW_DATA_CST)
-+		  {
-+		    tree elt_type;
-+		    conversion *next;
-+		    /* For conversion to initializer_list<unsigned char> or
-+		       initializer_list<char> or initializer_list<signed char>
-+		       we can optimize and keep RAW_DATA_CST with adjusted
-+		       type if we report narrowing errors if needed, for
-+		       others this converts each element separately.  */
-+		    if (convs->u.list[ix]->kind == ck_std
-+			&& (elt_type = convs->u.list[ix]->type)
-+			&& (TREE_CODE (elt_type) == INTEGER_TYPE
-+			    || is_byte_access_type (elt_type))
-+			&& TYPE_PRECISION (elt_type) == CHAR_BIT
-+			&& (next = next_conversion (convs->u.list[ix]))
-+			&& next->kind == ck_identity)
-+		      {
-+			if (!TYPE_UNSIGNED (elt_type)
-+			    && (TYPE_UNSIGNED (TREE_TYPE (val))
-+				|| (TYPE_PRECISION (TREE_TYPE (val))
-+				    > CHAR_BIT)))
-+			  for (int i = 0; i < RAW_DATA_LENGTH (val); ++i)
-+			    {
-+			      if (RAW_DATA_SCHAR_ELT (val, i) >= 0)
-+				continue;
-+			      else if (complain & tf_error)
-+				{
-+				  location_t loc
-+				    = cp_expr_loc_or_input_loc (val);
-+				  int savederrorcount = errorcount;
-+				  permerror_opt (loc, OPT_Wnarrowing,
-+						 "narrowing conversion of "
-+						 "%qd from %qH to %qI",
-+						 RAW_DATA_UCHAR_ELT (val, i),
-+						 TREE_TYPE (val), elt_type);
-+				  if (errorcount != savederrorcount)
-+				    return error_mark_node;
-+				}
-+			      else
-+				return error_mark_node;
-+			    }
-+			tree sub = copy_node (val);
-+			TREE_TYPE (sub) = elt_type;
-+			CONSTRUCTOR_APPEND_ELT (CONSTRUCTOR_ELTS (new_ctor),
-+						NULL_TREE, sub);
-+		      }
-+		    else
-+		      {
-+			for (int i = 0; i < RAW_DATA_LENGTH (val); ++i)
-+			  {
-+			    tree elt
-+			      = build_int_cst (TREE_TYPE (val),
-+					       RAW_DATA_UCHAR_ELT (val, i));
-+			    tree sub
-+			      = convert_like (convs->u.list[ix], elt,
-+					      fn, argnum, false, false,
-+					      /*nested_p=*/true, complain);
-+			    if (sub == error_mark_node)
-+			      return sub;
-+			    if (!check_narrowing (TREE_TYPE (sub), elt,
-+						  complain))
-+			      return error_mark_node;
-+			    tree nc = new_ctor;
-+			    CONSTRUCTOR_APPEND_ELT (CONSTRUCTOR_ELTS (nc),
-+						    NULL_TREE, sub);
-+			    if (!TREE_CONSTANT (sub))
-+			      TREE_CONSTANT (new_ctor) = false;
-+			  }
-+		      }
-+		    len += RAW_DATA_LENGTH (val) - 1;
-+		    continue;
-+		  }
- 		tree sub = convert_like (convs->u.list[ix], val, fn,
- 					 argnum, false, false,
- 					 /*nested_p=*/true, complain);
-@@ -8796,8 +8868,8 @@ convert_like_internal (conversion *convs, tree expr, tree fn, int argnum,
- 		  TREE_CONSTANT (new_ctor) = false;
- 	      }
- 	    /* Build up the array.  */
--	    elttype = cp_build_qualified_type
--	      (elttype, cp_type_quals (elttype) | TYPE_QUAL_CONST);
-+	    elttype = cp_build_qualified_type (elttype, cp_type_quals (elttype)
-+							| TYPE_QUAL_CONST);
- 	    array = build_array_of_n_type (elttype, len);
- 	    array = finish_compound_literal (array, new_ctor, complain);
- 	    /* This is dubious now, should be blessed by P2752.  */
-diff --git a/gcc/testsuite/g++.dg/cpp/embed-15.C b/gcc/testsuite/g++.dg/cpp/embed-15.C
-new file mode 100644
-index 000000000000..a3994536e576
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/cpp/embed-15.C
-@@ -0,0 +1,35 @@
-+// PR c++/118124
-+// { dg-do compile { target c++11 } }
-+// { dg-options "-O2" }
-+
-+namespace std {
-+template <class T> struct initializer_list {
-+private:
-+  const T *_M_array;
-+  __SIZE_TYPE__ _M_len;
-+};
-+}
-+struct A {
-+  A (std::initializer_list<char>);
-+};
-+A a {
-+#embed __FILE__
-+};
-+struct B {
-+  B (std::initializer_list<unsigned char>);
-+};
-+B b {
-+#embed __FILE__
-+};
-+struct C {
-+  C (std::initializer_list<int>);
-+};
-+C c {
-+#embed __FILE__
-+};
-+struct D {
-+  D (std::initializer_list<float>);
-+};
-+D d {
-+#embed __FILE__
-+};
-diff --git a/gcc/testsuite/g++.dg/cpp/embed-16.C b/gcc/testsuite/g++.dg/cpp/embed-16.C
-new file mode 100644
-index 000000000000..868dce2f165c
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/cpp/embed-16.C
-@@ -0,0 +1,18 @@
-+// PR c++/118124
-+// { dg-do compile { target c++11 } }
-+// { dg-options "-O2" }
-+// non-ASCII chars here: áéí
-+
-+namespace std {
-+template <class T> struct initializer_list {
-+private:
-+  const T *_M_array;
-+  __SIZE_TYPE__ _M_len;
-+};
-+}
-+struct A {
-+  A (std::initializer_list<signed char>);
-+};
-+A a {
-+#embed __FILE__
-+};	// { dg-error "narrowing conversion of '\[0-9]*' from 'int' to 'signed char'" }
-diff --git a/gcc/testsuite/g++.dg/cpp0x/initlist-opt3.C b/gcc/testsuite/g++.dg/cpp0x/initlist-opt3.C
-new file mode 100644
-index 000000000000..fa279882322d
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/cpp0x/initlist-opt3.C
-@@ -0,0 +1,47 @@
-+// PR c++/118124
-+// { dg-do compile { target c++11 } }
-+// { dg-options "-O2" }
-+
-+namespace std {
-+template <class T> struct initializer_list {
-+private:
-+  const T *_M_array;
-+  __SIZE_TYPE__ _M_len;
-+};
-+}
-+struct A {
-+  A (std::initializer_list<char>);
-+};
-+A a { 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7,
-+      8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
-+      0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1,
-+      2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3,
-+      4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5,
-+      6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5 };
-+struct B {
-+  B (std::initializer_list<unsigned char>);
-+};
-+B b { 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7,
-+      8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
-+      0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1,
-+      2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3,
-+      4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5,
-+      6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5 };
-+struct C {
-+  C (std::initializer_list<int>);
-+};
-+C c { 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7,
-+      8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
-+      0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1,
-+      2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3,
-+      4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5,
-+      6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5 };
-+struct D {
-+  D (std::initializer_list<float>);
-+};
-+D d { 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7,
-+      8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
-+      0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1,
-+      2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3,
-+      4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5,
-+      6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5 };
-diff --git a/gcc/testsuite/g++.dg/cpp0x/initlist-opt4.C b/gcc/testsuite/g++.dg/cpp0x/initlist-opt4.C
-new file mode 100644
-index 000000000000..080dee3cf026
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/cpp0x/initlist-opt4.C
-@@ -0,0 +1,20 @@
-+// PR c++/118124
-+// { dg-do compile { target c++11 } }
-+// { dg-options "-O2" }
-+
-+namespace std {
-+template <class T> struct initializer_list {
-+private:
-+  const T *_M_array;
-+  __SIZE_TYPE__ _M_len;
-+};
-+}
-+struct A {
-+  A (std::initializer_list<signed char>);
-+};
-+A a { 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7,
-+      8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
-+      0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1,
-+      2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 209, 0, 1, 2, 3,
-+      4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5,
-+      6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5 };	// { dg-error "narrowing conversion of '209' from 'int' to 'signed char'" }
-
-base-commit: 670df03e5294a31efff1554c9a751ef893dc1f71
--- 
-2.47.1
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-27 15:14 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-27 15:14 UTC (permalink / raw
  To: gentoo-commits
commit:     ef34a32cc0212d4e3bab226a047a8862185ffa68
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 27 15:14:49 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Dec 27 15:14:49 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ef34a32c
15.0.0: update README.history
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 69a95ed..4807210 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+35	????
+
+	- 79_all_PR118124-c-Fix-ICEs-with-large-initializer-lists-or-ones-i.patch
+
 34	24 December 2024
 
 	U 76_all_PR117854-config-nvptx-fix-bashisms-with-gen-copyright.sh-use.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-29 10:00 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-29 10:00 UTC (permalink / raw
  To: gentoo-commits
commit:     aa6770c7b16183f73410331f8363ddc0bf93d006
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 29 09:59:59 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec 29 09:59:59 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=aa6770c7
15.0.0: add 79_all_PR32491-fix-binutils-arm-check.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../79_all_PR32491-fix-binutils-arm-check.patch    | 128 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 129 insertions(+)
diff --git a/15.0.0/gentoo/79_all_PR32491-fix-binutils-arm-check.patch b/15.0.0/gentoo/79_all_PR32491-fix-binutils-arm-check.patch
new file mode 100644
index 0000000..7e9b847
--- /dev/null
+++ b/15.0.0/gentoo/79_all_PR32491-fix-binutils-arm-check.patch
@@ -0,0 +1,128 @@
+From 4f033ebeb8efb96f4f164e33d2536d1d18316052 Mon Sep 17 00:00:00 2001
+Message-ID: <4f033ebeb8efb96f4f164e33d2536d1d18316052.1735466357.git.sam@gentoo.org>
+From: Thiago Jung Bauermann <thiago.bauermann@linaro.org>
+Date: Fri, 27 Dec 2024 18:47:56 -0300
+Subject: [PATCH] gcc/configure: Fix check for assembler section merging
+ support on Arm
+
+In 32-bit Arm assembly, the @ character is the start of a comment so
+the section type needs to use the % character instead.
+
+configure.ac attempts to account for this difference by doing a second
+try when checking the assembler for section merging support.
+Unfortunately there is a bug: because the gcc_GAS_CHECK_FEATURE macro
+has a call to AC_CACHE_CHECK, it will actually skip the second try
+because the gcc_cv_as_shf_merge variable has already been set:
+
+  checking assembler for section merging support... no
+  checking assembler for section merging support... (cached) no
+
+Fix by using a separate variable for the second try, as is done in the
+check for COMDAT group support.
+
+This problem was noticed because the recent binutils commit
+d5cbf916be4a ("gas/ELF: also reject merge entity size being zero") caused
+gas to be stricter about mergeable sections without an entity size:
+
+configure:27013: checking assembler for section merging support
+configure:27022: /path/to/as   --fatal-warnings -o conftest.o conftest.s >&5
+conftest.s: Assembler messages:
+conftest.s:1: Warning: invalid merge / string entity size
+conftest.s: Error: 1 warning, treating warnings as errors
+configure:27025: $? = 1
+configure: failed program was
+.section .rodata.str, "aMS", @progbits, 1
+configure:27036: result: no
+
+In previous versions of gas the conftest.s program above was accepted
+and configure detected support for section merging.
+
+See also:
+https://linaro.atlassian.net/browse/GNU-1427
+https://sourceware.org/bugzilla/show_bug.cgi?id=32491
+
+Tested on armv8l-linux-gnueabihf.
+
+gcc/ChangeLog:
+	* configure.ac: Fix check for HAVE_GAS_SHF_MERGE on Arm targets.
+	* configure: Regenerate.
+---
+ gcc/configure    | 17 +++++++++--------
+ gcc/configure.ac |  6 ++++--
+ 2 files changed, 13 insertions(+), 10 deletions(-)
+
+diff --git a/gcc/configure b/gcc/configure
+index a8b531d8fae0..0bc33f0ede18 100755
+--- a/gcc/configure
++++ b/gcc/configure
+@@ -27038,12 +27038,12 @@ $as_echo "$gcc_cv_as_shf_merge" >&6; }
+ 
+ 
+ if test $gcc_cv_as_shf_merge = no; then
+-  { $as_echo "$as_me:${as_lineno-$LINENO}: checking assembler for section merging support" >&5
+-$as_echo_n "checking assembler for section merging support... " >&6; }
+-if ${gcc_cv_as_shf_merge+:} false; then :
++  { $as_echo "$as_me:${as_lineno-$LINENO}: checking assembler for section merging support (%progbits)" >&5
++$as_echo_n "checking assembler for section merging support (%progbits)... " >&6; }
++if ${gcc_cv_as_shf_merge_percent+:} false; then :
+   $as_echo_n "(cached) " >&6
+ else
+-  gcc_cv_as_shf_merge=no
++  gcc_cv_as_shf_merge_percent=no
+   if test x$gcc_cv_as != x; then
+     $as_echo '.section .rodata.str, "aMS", %progbits, 1' > conftest.s
+     if { ac_try='$gcc_cv_as $gcc_cv_as_flags --fatal-warnings -o conftest.o conftest.s >&5'
+@@ -27053,7 +27053,7 @@ else
+   $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
+   test $ac_status = 0; }; }
+     then
+-	gcc_cv_as_shf_merge=yes
++	gcc_cv_as_shf_merge_percent=yes
+     else
+       echo "configure: failed program was" >&5
+       cat conftest.s >&5
+@@ -27061,14 +27061,15 @@ else
+     rm -f conftest.o conftest.s
+   fi
+ fi
+-{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gcc_cv_as_shf_merge" >&5
+-$as_echo "$gcc_cv_as_shf_merge" >&6; }
++{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gcc_cv_as_shf_merge_percent" >&5
++$as_echo "$gcc_cv_as_shf_merge_percent" >&6; }
+ 
+ 
+ fi
+ 
+ cat >>confdefs.h <<_ACEOF
+-#define HAVE_GAS_SHF_MERGE `if test $gcc_cv_as_shf_merge = yes; then echo 1; else echo 0; fi`
++#define HAVE_GAS_SHF_MERGE `if test $gcc_cv_as_shf_merge = yes \
++    || test $gcc_cv_as_shf_merge_percent = yes; then echo 1; else echo 0; fi`
+ _ACEOF
+ 
+ 
+diff --git a/gcc/configure.ac b/gcc/configure.ac
+index 77fab885a428..1407c86e355b 100644
+--- a/gcc/configure.ac
++++ b/gcc/configure.ac
+@@ -3612,12 +3612,14 @@ gcc_GAS_CHECK_FEATURE(section merging support, gcc_cv_as_shf_merge,
+  [--fatal-warnings],
+  [.section .rodata.str, "aMS", @progbits, 1])
+ if test $gcc_cv_as_shf_merge = no; then
+-  gcc_GAS_CHECK_FEATURE(section merging support, gcc_cv_as_shf_merge,
++  gcc_GAS_CHECK_FEATURE(section merging support (%progbits),
++    gcc_cv_as_shf_merge_percent,
+     [--fatal-warnings],
+     [.section .rodata.str, "aMS", %progbits, 1])
+ fi
+ AC_DEFINE_UNQUOTED(HAVE_GAS_SHF_MERGE,
+-  [`if test $gcc_cv_as_shf_merge = yes; then echo 1; else echo 0; fi`],
++  [`if test $gcc_cv_as_shf_merge = yes \
++    || test $gcc_cv_as_shf_merge_percent = yes; then echo 1; else echo 0; fi`],
+ [Define 0/1 if your assembler supports marking sections with SHF_MERGE flag.])
+ 
+ gcc_GAS_CHECK_FEATURE([COMDAT group support (GNU as)],
+
+base-commit: 4da027d87eabd9a6cb0f5c1ed7ee10540501c7a3
+-- 
+2.47.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 4807210..3fb826b 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 35	????
 
 	- 79_all_PR118124-c-Fix-ICEs-with-large-initializer-lists-or-ones-i.patch
+	+ 79_all_PR32491-fix-binutils-arm-check.patch
 
 34	24 December 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2024-12-30  1:05 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2024-12-30  1:05 UTC (permalink / raw
  To: gentoo-commits
commit:     7d79e27cec8ee7e1e3974e4d07e5b0fa7246d274
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 30 01:05:14 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Dec 30 01:05:14 2024 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=7d79e27c
15.0.0: cut patchset 35
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 3fb826b..8cbb0f1 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-35	????
+35	30 December 2024
 
 	- 79_all_PR118124-c-Fix-ICEs-with-large-initializer-lists-or-ones-i.patch
 	+ 79_all_PR32491-fix-binutils-arm-check.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-03  3:07 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-03  3:07 UTC (permalink / raw
  To: gentoo-commits
commit:     8ae1499b27e26709cfee97cc49ef61ecf6a40836
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Jan  3 03:06:40 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jan  3 03:06:40 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=8ae1499b
15.0.0: drop upstream 73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-c-special-case-some-bool-errors-with-C23.patch | 312 ---------------------
 15.0.0/gentoo/README.history                       |   4 +
 2 files changed, 4 insertions(+), 312 deletions(-)
diff --git a/15.0.0/gentoo/73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch b/15.0.0/gentoo/73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch
deleted file mode 100644
index 3c3696e..0000000
--- a/15.0.0/gentoo/73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch
+++ /dev/null
@@ -1,312 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/20241126034902.1294094-1-dmalcolm@redhat.com/
-
-From 3d35e4348a0771cedc5a540f70eaa90f3ea68f23 Mon Sep 17 00:00:00 2001
-Message-ID: <3d35e4348a0771cedc5a540f70eaa90f3ea68f23.1733506366.git.sam@gentoo.org>
-From: David Malcolm <dmalcolm@redhat.com>
-Date: Mon, 25 Nov 2024 22:49:02 -0500
-Subject: [PATCH] c: special-case some "bool" errors with C23 [PR117629]
-
-This patch attempts to provide better error messages for
-code compiled with C23 that hasn't been updated for
-"bool", "true", and "false" becoming keywords (based on
-a brief review of the Gentoo bug tracker links given at
-https://gcc.gnu.org/pipermail/gcc/2024-November/245185.html).
-
-Specifically:
-
-(1) with "typedef int bool;" previously we emitted:
-
-t1.c:7:13: error: two or more data types in declaration specifiers
-    7 | typedef int bool;
-      |             ^~~~
-t1.c:7:1: warning: useless type name in empty declaration
-    7 | typedef int bool;
-      | ^~~~~~~
-
-whereas with this patch we emit:
-
-t1.c:7:13: error: 'bool' cannot be defined via 'typedef'
-    7 | typedef int bool;
-      |             ^~~~
-t1.c:7:13: note: 'bool' is a keyword with '-std=c23' onwards
-t1.c:7:1: warning: useless type name in empty declaration
-    7 | typedef int bool;
-      | ^~~~~~~
-
-(2) with "int bool;" previously we emitted:
-
-t2.c:7:5: error: two or more data types in declaration specifiers
-    7 | int bool;
-      |     ^~~~
-t2.c:7:1: warning: useless type name in empty declaration
-    7 | int bool;
-      | ^~~
-
-whereas with this patch we emit:
-
-t2.c:7:5: error: 'bool' cannot be used here
-    7 | int bool;
-      |     ^~~~
-t2.c:7:5: note: 'bool' is a keyword with '-std=c23' onwards
-t2.c:7:1: warning: useless type name in empty declaration
-    7 | int bool;
-      | ^~~
-
-(3) with "typedef enum { false = 0, true = 1 } _Bool;" previously we
-emitted:
-
-t3.c:7:16: error: expected identifier before 'false'
-    7 | typedef enum { false = 0, true = 1 } _Bool;
-      |                ^~~~~
-t3.c:7:38: error: expected ';', identifier or '(' before '_Bool'
-    7 | typedef enum { false = 0, true = 1 } _Bool;
-      |                                      ^~~~~
-t3.c:7:38: warning: useless type name in empty declaration
-
-whereas with this patch we emit:
-
-t3.c:7:16: error: cannot use keyword 'false' as enumeration constant
-    7 | typedef enum { false = 0, true = 1 } _Bool;
-      |                ^~~~~
-t3.c:7:16: note: 'false' is a keyword with '-std=c23' onwards
-t3.c:7:38: error: expected ';', identifier or '(' before '_Bool'
-    7 | typedef enum { false = 0, true = 1 } _Bool;
-      |                                      ^~~~~
-t3.c:7:38: warning: useless type name in empty declaration
-
-Successfully bootstrapped & regrtested on x86_64-pc-linux-gnu.
-OK for trunk?
-
-gcc/c/ChangeLog:
-	PR c/117629
-	* c-decl.cc (declspecs_add_type): Special-case attempts to use
-	bool as a typedef name or declaration name.
-	* c-errors.cc (add_note_about_new_keyword): New.
-	* c-parser.cc (report_bad_enum_name): New, split out from...
-	(c_parser_enum_specifier): ...here, adding handling for RID_FALSE
-	and RID_TRUE.
-	* c-tree.h (add_note_about_new_keyword): New decl.
-
-gcc/testsuite/ChangeLog:
-	PR c/117629
-	* gcc.dg/auto-type-2.c: Update expected output with _Bool.
-	* gcc.dg/c23-bool-errors-1.c: New test.
-	* gcc.dg/c23-bool-errors-2.c: New test.
-	* gcc.dg/c23-bool-errors-3.c: New test.
-
-Signed-off-by: David Malcolm <dmalcolm@redhat.com>
----
- gcc/c/c-decl.cc                          | 18 +++++++-
- gcc/c/c-errors.cc                        | 13 ++++++
- gcc/c/c-parser.cc                        | 53 +++++++++++++++++++-----
- gcc/c/c-tree.h                           |  3 ++
- gcc/testsuite/gcc.dg/auto-type-2.c       |  2 +-
- gcc/testsuite/gcc.dg/c23-bool-errors-1.c |  9 ++++
- gcc/testsuite/gcc.dg/c23-bool-errors-2.c |  9 ++++
- gcc/testsuite/gcc.dg/c23-bool-errors-3.c | 15 +++++++
- 8 files changed, 109 insertions(+), 13 deletions(-)
- create mode 100644 gcc/testsuite/gcc.dg/c23-bool-errors-1.c
- create mode 100644 gcc/testsuite/gcc.dg/c23-bool-errors-2.c
- create mode 100644 gcc/testsuite/gcc.dg/c23-bool-errors-3.c
-
-diff --git a/gcc/c/c-decl.cc b/gcc/c/c-decl.cc
-index 7abf1921b577..91d5fee50402 100644
---- a/gcc/c/c-decl.cc
-+++ b/gcc/c/c-decl.cc
-@@ -12493,8 +12493,22 @@ declspecs_add_type (location_t loc, struct c_declspecs *specs,
- 	     "__auto_type".  */
- 	  if (specs->typespec_word != cts_none)
- 	    {
--	      error_at (loc,
--			"two or more data types in declaration specifiers");
-+	      if (i == RID_BOOL)
-+		{
-+		  auto_diagnostic_group d;
-+		  if (specs->storage_class == csc_typedef)
-+		    error_at (loc,
-+			      "%qs cannot be defined via %<typedef%>",
-+			      IDENTIFIER_POINTER (type));
-+		  else
-+		    error_at (loc,
-+			      "%qs cannot be used here",
-+			      IDENTIFIER_POINTER (type));
-+		  add_note_about_new_keyword (loc, type, "-std=c23");
-+		}
-+	      else
-+		error_at (loc,
-+			  "two or more data types in declaration specifiers");
- 	      return specs;
- 	    }
- 	  switch (i)
-diff --git a/gcc/c/c-errors.cc b/gcc/c/c-errors.cc
-index 77f008eba1c2..cc9bb128ee8b 100644
---- a/gcc/c/c-errors.cc
-+++ b/gcc/c/c-errors.cc
-@@ -215,3 +215,16 @@ out:
-   va_end (ap);
-   return warned;
- }
-+
-+/* Issue a note to the user at LOC that KEYWORD_ID is a keyword
-+   in STD_OPTION version of the standard onwards.  */
-+
-+void
-+add_note_about_new_keyword (location_t loc,
-+			    tree keyword_id,
-+			    const char *std_option)
-+{
-+  gcc_assert (TREE_CODE (keyword_id) == IDENTIFIER_NODE);
-+  inform (loc, "%qs is a keyword with %qs onwards",
-+	  IDENTIFIER_POINTER (keyword_id), std_option);
-+}
-diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
-index 4ec0ee85ac49..18ba82e83f02 100644
---- a/gcc/c/c-parser.cc
-+++ b/gcc/c/c-parser.cc
-@@ -3785,6 +3785,48 @@ c_parser_declspecs (c_parser *parser, struct c_declspecs *specs,
-     specs->postfix_attrs = c_parser_std_attribute_specifier_sequence (parser);
- }
- 
-+/* Complain about a non-CPP_NAME within an enumerator list.  */
-+
-+static void
-+report_bad_enum_name (c_parser *parser)
-+{
-+  if (!parser->error)
-+    {
-+      c_token *token = c_parser_peek_token (parser);
-+      switch (token->type)
-+	{
-+	default:
-+	  break;
-+	case CPP_CLOSE_BRACE:
-+	  /* Give a nicer error for "enum {}".  */
-+	  error_at (token->location,
-+		    "empty enum is invalid");
-+	  parser->error = true;
-+	  return;
-+	case CPP_KEYWORD:
-+	  /* Give a nicer error for attempts to use "true" and "false"
-+	     in enums with C23 onwards.  */
-+	  if (token->keyword == RID_FALSE
-+	      || token->keyword == RID_TRUE)
-+	    {
-+	      auto_diagnostic_group d;
-+	      error_at (token->location,
-+			"cannot use keyword %qs as enumeration constant",
-+			IDENTIFIER_POINTER (token->value));
-+	      add_note_about_new_keyword (token->location,
-+					  token->value,
-+					  "-std=c23");
-+	      parser->error = true;
-+	      return;
-+	    }
-+	  break;
-+	}
-+    }
-+
-+  /* Otherwise, a more generic error message.  */
-+  c_parser_error (parser, "expected identifier");
-+}
-+
- /* Parse an enum specifier (C90 6.5.2.2, C99 6.7.2.2, C11 6.7.2.2).
- 
-    enum-specifier:
-@@ -3952,16 +3994,7 @@ c_parser_enum_specifier (c_parser *parser)
- 	  location_t decl_loc, value_loc;
- 	  if (c_parser_next_token_is_not (parser, CPP_NAME))
- 	    {
--	      /* Give a nicer error for "enum {}".  */
--	      if (c_parser_next_token_is (parser, CPP_CLOSE_BRACE)
--		  && !parser->error)
--		{
--		  error_at (c_parser_peek_token (parser)->location,
--			    "empty enum is invalid");
--		  parser->error = true;
--		}
--	      else
--		c_parser_error (parser, "expected identifier");
-+	      report_bad_enum_name (parser);
- 	      c_parser_skip_until_found (parser, CPP_CLOSE_BRACE, NULL);
- 	      values = error_mark_node;
- 	      break;
-diff --git a/gcc/c/c-tree.h b/gcc/c/c-tree.h
-index d39bd238103e..e98bd4f2fd8d 100644
---- a/gcc/c/c-tree.h
-+++ b/gcc/c/c-tree.h
-@@ -955,6 +955,9 @@ extern bool pedwarn_c11 (location_t, diagnostic_option_id, const char *, ...)
-     ATTRIBUTE_GCC_DIAG(3,4);
- extern bool pedwarn_c23 (location_t, diagnostic_option_id, const char *, ...)
-     ATTRIBUTE_GCC_DIAG(3,4);
-+extern void add_note_about_new_keyword (location_t loc,
-+					tree keyword_id,
-+					const char *std_option);
- 
- extern void
- set_c_expr_source_range (c_expr *expr,
-diff --git a/gcc/testsuite/gcc.dg/auto-type-2.c b/gcc/testsuite/gcc.dg/auto-type-2.c
-index 761671b3c5a4..f484acb4c916 100644
---- a/gcc/testsuite/gcc.dg/auto-type-2.c
-+++ b/gcc/testsuite/gcc.dg/auto-type-2.c
-@@ -20,4 +20,4 @@ signed __auto_type e7 = 0; /* { dg-error "__auto_type" } */
- unsigned __auto_type e8 = 0; /* { dg-error "__auto_type" } */
- _Complex __auto_type e9 = 0; /* { dg-error "__auto_type" } */
- int __auto_type e10 = 0; /* { dg-error "two or more data types" } */
--__auto_type _Bool e11 = 0; /* { dg-error "two or more data types" } */
-+__auto_type _Bool e11 = 0; /* { dg-error "'_Bool' cannot be used here" } */
-diff --git a/gcc/testsuite/gcc.dg/c23-bool-errors-1.c b/gcc/testsuite/gcc.dg/c23-bool-errors-1.c
-new file mode 100644
-index 000000000000..8a33d36a8891
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/c23-bool-errors-1.c
-@@ -0,0 +1,9 @@
-+/* Test error-handling for legacy code that tries to
-+   define "bool" with C23.  */
-+
-+/* { dg-do compile } */
-+/* { dg-options "-std=c23" } */
-+
-+typedef int bool; /* { dg-error "'bool' cannot be defined via 'typedef'" } */
-+/* { dg-message "'bool' is a keyword with '-std=c23' onwards" "" { target *-*-* } .-1 } */
-+/* { dg-warning "useless type name in empty declaration"  "" { target *-*-* } .-2 } */
-diff --git a/gcc/testsuite/gcc.dg/c23-bool-errors-2.c b/gcc/testsuite/gcc.dg/c23-bool-errors-2.c
-new file mode 100644
-index 000000000000..1a66e3aea67e
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/c23-bool-errors-2.c
-@@ -0,0 +1,9 @@
-+/* Test error-handling for legacy code that tries to
-+   use a variable named "bool" with C23.  */
-+
-+/* { dg-do compile } */
-+/* { dg-options "-std=c23" } */
-+
-+int bool; /* { dg-error "'bool' cannot be used here" } */
-+/* { dg-message "'bool' is a keyword with '-std=c23' onwards" "" { target *-*-* } .-1 } */
-+/* { dg-warning "useless type name in empty declaration" "" { target *-*-* } .-2 } */
-diff --git a/gcc/testsuite/gcc.dg/c23-bool-errors-3.c b/gcc/testsuite/gcc.dg/c23-bool-errors-3.c
-new file mode 100644
-index 000000000000..634c8ac45a52
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/c23-bool-errors-3.c
-@@ -0,0 +1,15 @@
-+/* Test error-handling for legacy code that tries to
-+   define "false" or "true" within enums with C23.  */
-+
-+/* { dg-do compile } */
-+/* { dg-options "-std=c23" } */
-+
-+typedef enum { false = 0, true = 1 } _Bool; /* { dg-error "cannot use keyword 'false' as enumeration constant" }
-+/* { dg-message "'false' is a keyword with '-std=c23' onwards" "" { target *-*-* } .-1 } */
-+/* { dg-error "38: expected ';', identifier or '\\\(' before '_Bool'" "" { target *-*-* } .-2 } */
-+/* { dg-warning "38: useless type name in empty declaration" "" { target *-*-* } .-3 } */
-+
-+typedef enum { true = 1, false = 0 } _Bool; /* { dg-error "cannot use keyword 'true' as enumeration constant" }
-+/* { dg-message "'true' is a keyword with '-std=c23' onwards" "" { target *-*-* } .-1 } */
-+/* { dg-error "38: expected ';', identifier or '\\\(' before '_Bool'" "" { target *-*-* } .-2 } */
-+/* { dg-warning "38: useless type name in empty declaration" "" { target *-*-* } .-3 } */
-
-base-commit: 115e4bf54ec91a4f358a9e68dcd7a234b0ccc5b8
--- 
-2.47.1
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 8cbb0f1..5fb0734 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+36	????
+
+	- 73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch
+
 35	30 December 2024
 
 	- 79_all_PR118124-c-Fix-ICEs-with-large-initializer-lists-or-ones-i.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-05 23:19 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-05 23:19 UTC (permalink / raw
  To: gentoo-commits
commit:     25a028be960939385c2272baa3b36ef62703e9e5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jan  5 23:18:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jan  5 23:18:30 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=25a028be
15.0.0: cut patchset 36
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 5fb0734..ea310c3 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-36	????
+36	5 January 2025
 
 	- 73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-06  4:03 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-06  4:03 UTC (permalink / raw
  To: gentoo-commits
commit:     c1ac1ff6f687e8612b003b96a8d768f47c41218a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  6 04:02:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan  6 04:02:50 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=c1ac1ff6
15.0.0: add 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
At https://gcc.gnu.org/bugzilla/show_bug.cgi?id=81358#c22, testing
was requested before merging, so let's do that (not least because
this will help us a lot).
Bug: https://gcc.gnu.org/PR81358
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...358-Enable-automatic-linking-of-libatomic.patch | 1493 ++++++++++++++++++++
 15.0.0/gentoo/README.history                       |    4 +
 2 files changed, 1497 insertions(+)
diff --git a/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch b/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
new file mode 100644
index 0000000..61fdc80
--- /dev/null
+++ b/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
@@ -0,0 +1,1493 @@
+From 15810d4218a601c42a9f5bf264761c3b2bab37ff Mon Sep 17 00:00:00 2001
+Message-ID: <15810d4218a601c42a9f5bf264761c3b2bab37ff.1736136101.git.sam@gentoo.org>
+From: Prathamesh Kulkarni <prathameshk@nvidia.com>
+Date: Sat, 16 Nov 2024 03:44:26 +0000
+Subject: [PATCH] PR81358: Enable automatic linking of libatomic
+
+PR81358: Enable automatic linking of libatomic.
+
+ChangeLog:
+	PR driver/81358
+	* Makefile.def: Add dependencies so libatomic is built before target
+	libraries are configured.
+	* configure.ac: Add libatomic to bootstrap_target_libs.
+	* Makefile.in: Regenerate.
+	* configure: Regenerate.
+
+gcc/ChangeLog:
+	PR driver/81358
+	* common.opt: New option -flink-atomic.
+	* config/gnu-user.h (GNU_USER_TARGET_LINK_GCC_C_SEQUENCE_SPEC): Use
+	LINK_LIBATOMIC_SPEC.
+	* gcc.cc (LINK_LIBATOMIC_SPEC): New macro.
+
+libatomic/ChangeLog:
+	PR driver/81358
+	* Makefile.am: Pass -fno-link-atomic.
+	New rule all.
+	* configure.ac: Pass -fno-link-atomic.
+	* Makefile.in: Regenerate.
+	* aclocal.m4: Regenerate.
+	* configure: Regenerate.
+	* testsuite/Makefile.in: Regenerate.
+
+Signed-off-by: Prathamesh Kulkarni <prathameshk@nvidia.com>
+Co-authored-by: Matthew Malcolmson <mmalcolmson@nvidia.com>
+---
+ Makefile.def                    |  20 +++
+ Makefile.in                     | 112 ++++++++++++++++
+ configure                       |  19 ++-
+ configure.ac                    |   5 +
+ gcc/common.opt                  |   3 +
+ gcc/config/gnu-user.h           |   3 +-
+ gcc/gcc.cc                      |   7 +
+ libatomic/Makefile.am           |  13 +-
+ libatomic/Makefile.in           | 107 ++++++++++-----
+ libatomic/aclocal.m4            | 191 +++++++++++++--------------
+ libatomic/configure             | 224 +++++++++++++++++---------------
+ libatomic/configure.ac          |  13 +-
+ libatomic/testsuite/Makefile.in |  11 +-
+ 13 files changed, 473 insertions(+), 255 deletions(-)
+
+diff --git a/Makefile.def b/Makefile.def
+index 19954e7d7318..90899fa28cf0 100644
+--- a/Makefile.def
++++ b/Makefile.def
+@@ -656,6 +656,26 @@ lang_env_dependencies = { module=libgcc; no_gcc=true; no_c=true; };
+ // a dependency on libgcc for native targets to configure.
+ lang_env_dependencies = { module=libiberty; no_c=true; };
+ 
++dependencies = { module=configure-target-libbacktrace; on=all-target-libatomic; };
++dependencies = { module=configure-target-libgloss; on=all-target-libatomic; };
++dependencies = { module=configure-target-newlib; on=all-target-libatomic; };
++dependencies = { module=configure-target-libgomp; on=all-target-libatomic; };
++dependencies = { module=configure-target-libitm; on=all-target-libatomic; };
++dependencies = { module=configure-target-libstdc++v3; on=all-target-libatomic; };
++dependencies = { module=configure-target-libsanitizer; on=all-target-libatomic; };
++dependencies = { module=configure-target-libvtv; on=all-target-libatomic; };
++dependencies = { module=configure-target-libssp; on=all-target-libatomic; };
++dependencies = { module=configure-target-libquadmath; on=all-target-libatomic; };
++dependencies = { module=configure-target-libgfortran; on=all-target-libatomic; };
++dependencies = { module=configure-target-libffi; on=all-target-libatomic; };
++dependencies = { module=configure-target-libobjc; on=all-target-libatomic; };
++dependencies = { module=configure-target-libada; on=all-target-libatomic; };
++dependencies = { module=configure-target-libgm2; on=all-target-libatomic; };
++dependencies = { module=configure-target-libgo; on=all-target-libatomic; };
++dependencies = { module=configure-target-libgrust; on=all-target-libatomic; };
++dependencies = { module=configure-target-libphobos; on=all-target-libatomic; };
++dependencies = { module=configure-target-zlib; on=all-target-libatomic; };
++
+ dependencies = { module=configure-target-fastjar; on=configure-target-zlib; };
+ dependencies = { module=all-target-fastjar; on=all-target-zlib; };
+ dependencies = { module=configure-target-libgo; on=configure-target-libffi; };
+diff --git a/Makefile.in b/Makefile.in
+index 966d60454960..5295929bfa9b 100644
+--- a/Makefile.in
++++ b/Makefile.in
+@@ -68551,6 +68551,66 @@ all-flex: maybe-all-build-bison
+ all-flex: maybe-all-m4
+ all-flex: maybe-all-build-texinfo
+ all-m4: maybe-all-build-texinfo
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
+ configure-target-libgo: maybe-configure-target-libffi
+ all-target-libgo: maybe-all-target-libffi
+ configure-target-libphobos: maybe-configure-target-libbacktrace
+@@ -68678,6 +68738,45 @@ configure-m4: stage_last
+ @endif gcc-bootstrap
+ 
+ @if gcc-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libgloss: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-newlib: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libitm: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libstdc++v3: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libssp: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libquadmath: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libgfortran: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libffi: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libobjc: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libada: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libgm2: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libgo: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libgrust: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
+ @unless target-zlib-bootstrap
+ configure-target-fastjar: maybe-configure-target-zlib
+ @endunless target-zlib-bootstrap
+@@ -68755,6 +68854,19 @@ all-fastjar: maybe-all-libiberty
+ all-bison: maybe-all-gettext
+ all-flex: maybe-all-gettext
+ all-m4: maybe-all-gettext
++configure-target-libgloss: maybe-all-target-libatomic
++configure-target-newlib: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libstdc++v3: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
+ configure-target-fastjar: maybe-configure-target-zlib
+ all-target-fastjar: maybe-all-target-zlib
+ configure-target-libgo: maybe-all-target-libstdc++-v3
+diff --git a/configure b/configure
+index 4ae8e1242afa..376898374a29 100755
+--- a/configure
++++ b/configure
+@@ -776,6 +776,7 @@ infodir
+ docdir
+ oldincludedir
+ includedir
++runstatedir
+ localstatedir
+ sharedstatedir
+ sysconfdir
+@@ -951,6 +952,7 @@ datadir='${datarootdir}'
+ sysconfdir='${prefix}/etc'
+ sharedstatedir='${prefix}/com'
+ localstatedir='${prefix}/var'
++runstatedir='${localstatedir}/run'
+ includedir='${prefix}/include'
+ oldincludedir='/usr/include'
+ docdir='${datarootdir}/doc/${PACKAGE}'
+@@ -1203,6 +1205,15 @@ do
+   | -silent | --silent | --silen | --sile | --sil)
+     silent=yes ;;
+ 
++  -runstatedir | --runstatedir | --runstatedi | --runstated \
++  | --runstate | --runstat | --runsta | --runst | --runs \
++  | --run | --ru | --r)
++    ac_prev=runstatedir ;;
++  -runstatedir=* | --runstatedir=* | --runstatedi=* | --runstated=* \
++  | --runstate=* | --runstat=* | --runsta=* | --runst=* | --runs=* \
++  | --run=* | --ru=* | --r=*)
++    runstatedir=$ac_optarg ;;
++
+   -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb)
+     ac_prev=sbindir ;;
+   -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \
+@@ -1340,7 +1351,7 @@ fi
+ for ac_var in	exec_prefix prefix bindir sbindir libexecdir datarootdir \
+ 		datadir sysconfdir sharedstatedir localstatedir includedir \
+ 		oldincludedir docdir infodir htmldir dvidir pdfdir psdir \
+-		libdir localedir mandir
++		libdir localedir mandir runstatedir
+ do
+   eval ac_val=\$$ac_var
+   # Remove trailing slashes.
+@@ -1500,6 +1511,7 @@ Fine tuning of the installation directories:
+   --sysconfdir=DIR        read-only single-machine data [PREFIX/etc]
+   --sharedstatedir=DIR    modifiable architecture-independent data [PREFIX/com]
+   --localstatedir=DIR     modifiable single-machine data [PREFIX/var]
++  --runstatedir=DIR       modifiable per-process data [LOCALSTATEDIR/run]
+   --libdir=DIR            object code libraries [EPREFIX/lib]
+   --includedir=DIR        C header files [PREFIX/include]
+   --oldincludedir=DIR     C header files for non-gcc [/usr/include]
+@@ -10924,6 +10936,11 @@ if echo " ${target_configdirs} " | grep " libgomp " > /dev/null 2>&1 ; then
+   bootstrap_target_libs=${bootstrap_target_libs}target-libgomp,
+ fi
+ 
++# If we are building libatomic, bootstrap it.
++if echo " ${target_configdirs} " | grep " libatomic " > /dev/null 2>&1 ; then
++  bootstrap_target_libs=${bootstrap_target_libs}target-libatomic,
++fi
++
+ # If we are building libsanitizer and $BUILD_CONFIG contains bootstrap-asan
+ # or bootstrap-ubsan, bootstrap it.
+ if echo " ${target_configdirs} " | grep " libsanitizer " > /dev/null 2>&1; then
+diff --git a/configure.ac b/configure.ac
+index 9a72b2311bdd..c44d84f32ce1 100644
+--- a/configure.ac
++++ b/configure.ac
+@@ -3151,6 +3151,11 @@ if echo " ${target_configdirs} " | grep " libgomp " > /dev/null 2>&1 ; then
+   bootstrap_target_libs=${bootstrap_target_libs}target-libgomp,
+ fi
+ 
++# If we are building libatomic, bootstrap it.
++if echo " ${target_configdirs} " | grep " libatomic " > /dev/null 2>&1 ; then
++  bootstrap_target_libs=${bootstrap_target_libs}target-libatomic,
++fi
++
+ # If we are building libsanitizer and $BUILD_CONFIG contains bootstrap-asan
+ # or bootstrap-ubsan, bootstrap it.
+ if echo " ${target_configdirs} " | grep " libsanitizer " > /dev/null 2>&1; then
+diff --git a/gcc/common.opt b/gcc/common.opt
+index e2ac99df1d0d..cbb6a791c89d 100644
+--- a/gcc/common.opt
++++ b/gcc/common.opt
+@@ -3361,6 +3361,9 @@ Use the Modern linker (MOLD) linker instead of the default linker.
+ fuse-linker-plugin
+ Common Undocumented Var(flag_use_linker_plugin)
+ 
++flink-libatomic
++Common Driver Var(flag_link_libatomic) Init(1)
++
+ ; Positive if we should track variables, negative if we should run
+ ; the var-tracking pass only to discard debug annotations, zero if
+ ; we're not to run it.
+diff --git a/gcc/config/gnu-user.h b/gcc/config/gnu-user.h
+index 4c4e31efa393..151871540e7b 100644
+--- a/gcc/config/gnu-user.h
++++ b/gcc/config/gnu-user.h
+@@ -109,8 +109,9 @@ see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
+ #define LINK_EH_SPEC "%{!static|static-pie:--eh-frame-hdr} "
+ #endif
+ 
++
+ #define GNU_USER_TARGET_LINK_GCC_C_SEQUENCE_SPEC \
+-  "%{static|static-pie:--start-group} %G %{!nolibc:%L} \
++  "%{static|static-pie:--start-group} %G %{!nolibc:" LINK_LIBATOMIC_SPEC "%L} \
+    %{static|static-pie:--end-group}%{!static:%{!static-pie:%G}}"
+ 
+ #undef LINK_GCC_C_SEQUENCE_SPEC
+diff --git a/gcc/gcc.cc b/gcc/gcc.cc
+index 95b98eaa83cf..815558ab38b1 100644
+--- a/gcc/gcc.cc
++++ b/gcc/gcc.cc
+@@ -980,6 +980,13 @@ proper position among the other output files.  */
+ 
+ /* Here is the spec for running the linker, after compiling all files.  */
+ 
++#ifdef USE_LD_AS_NEEDED
++#define LINK_LIBATOMIC_SPEC "%{!fno-link-libatomic:" LD_AS_NEEDED_OPTION \
++			    " -latomic " LD_NO_AS_NEEDED_OPTION "} "
++#else
++#define LINK_LIBATOMIC_SPEC ""
++#endif
++
+ /* This is overridable by the target in case they need to specify the
+    -lgcc and -lc order specially, yet not require them to override all
+    of LINK_COMMAND_SPEC.  */
+diff --git a/libatomic/Makefile.am b/libatomic/Makefile.am
+index 0f1a71560848..9f83ef6cd913 100644
+--- a/libatomic/Makefile.am
++++ b/libatomic/Makefile.am
+@@ -35,9 +35,9 @@ search_path = $(addprefix $(top_srcdir)/config/, $(config_path)) \
+ vpath % $(strip $(search_path))
+ 
+ DEFAULT_INCLUDES = $(addprefix -I, $(search_path))
+-AM_CFLAGS = $(XCFLAGS)
+-AM_CCASFLAGS = $(XCFLAGS)
+-AM_LDFLAGS = $(XLDFLAGS) $(SECTION_LDFLAGS) $(OPT_LDFLAGS)
++AM_CFLAGS = $(XCFLAGS) -fno-link-libatomic
++AM_CCASFLAGS = $(XCFLAGS) -fno-link-libatomic
++AM_LDFLAGS = $(XLDFLAGS) $(SECTION_LDFLAGS) $(OPT_LDFLAGS) -fno-link-libatomic
+ 
+ toolexeclib_LTLIBRARIES = libatomic.la
+ noinst_LTLIBRARIES = libatomic_convenience.la
+@@ -69,7 +69,7 @@ libatomic_darwin_rpath += -Wl,-rpath,@loader_path
+ endif
+ 
+ libatomic_la_LDFLAGS = $(libatomic_version_info) $(libatomic_version_script) \
+-	$(lt_host_flags) $(libatomic_darwin_rpath)
++	-Wc,-fno-link-libatomic $(lt_host_flags) $(libatomic_darwin_rpath)
+ libatomic_la_SOURCES = gload.c gstore.c gcas.c gexch.c glfree.c lock.c init.c \
+ 	fenv.c fence.c flag.c
+ 
+@@ -162,6 +162,11 @@ libatomic_convenience_la_LIBADD = $(libatomic_la_LIBADD)
+ # when it is reloaded during the build of all-multi.
+ all-multi: $(libatomic_la_LIBADD)
+ 
++gcc_objdir = $(MULTIBUILDTOP)../../$(host_subdir)/gcc
++all: all-multi libatomic.la
++	$(INSTALL_DATA) .libs/libatomic.a $(gcc_objdir)/
++	chmod 644 $(gcc_objdir)/libatomic.a
++
+ # target overrides
+ -include $(tmake_file)
+ 
+diff --git a/libatomic/Makefile.in b/libatomic/Makefile.in
+index 9798e7c09e99..62cd5e0a76b3 100644
+--- a/libatomic/Makefile.in
++++ b/libatomic/Makefile.in
+@@ -1,7 +1,7 @@
+-# Makefile.in generated by automake 1.15.1 from Makefile.am.
++# Makefile.in generated by automake 1.16.1 from Makefile.am.
+ # @configure_input@
+ 
+-# Copyright (C) 1994-2017 Free Software Foundation, Inc.
++# Copyright (C) 1994-2018 Free Software Foundation, Inc.
+ 
+ # This Makefile.in is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -187,11 +187,16 @@ am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
+ am__v_at_0 = @
+ am__v_at_1 = 
+ depcomp = $(SHELL) $(top_srcdir)/../depcomp
+-am__depfiles_maybe = depfiles
++am__maybe_remake_depfiles = depfiles
++am__depfiles_remade = ./$(DEPDIR)/atomic_16.Plo ./$(DEPDIR)/fence.Plo \
++	./$(DEPDIR)/fenv.Plo ./$(DEPDIR)/flag.Plo ./$(DEPDIR)/gcas.Plo \
++	./$(DEPDIR)/gexch.Plo ./$(DEPDIR)/glfree.Plo \
++	./$(DEPDIR)/gload.Plo ./$(DEPDIR)/gstore.Plo \
++	./$(DEPDIR)/init.Plo ./$(DEPDIR)/lock.Plo
+ am__mv = mv -f
+ CPPASCOMPILE = $(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \
+ 	$(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CCASFLAGS) $(CCASFLAGS)
+-LTCPPASCOMPILE = $(LIBTOOL) $(AM_V_lt) $(AM_LIBTOOLFLAGS) \
++LTCPPASCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
+ 	$(LIBTOOLFLAGS) --mode=compile $(CCAS) $(DEFS) \
+ 	$(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \
+ 	$(AM_CCASFLAGS) $(CCASFLAGS)
+@@ -383,6 +388,7 @@ pdfdir = @pdfdir@
+ prefix = @prefix@
+ program_transform_name = @program_transform_name@
+ psdir = @psdir@
++runstatedir = @runstatedir@
+ sbindir = @sbindir@
+ sharedstatedir = @sharedstatedir@
+ srcdir = @srcdir@
+@@ -405,9 +411,9 @@ search_path = $(addprefix $(top_srcdir)/config/, $(config_path)) \
+ 	$(top_srcdir) $(top_builddir)
+ 
+ DEFAULT_INCLUDES = $(addprefix -I, $(search_path))
+-AM_CFLAGS = $(XCFLAGS)
+-AM_CCASFLAGS = $(XCFLAGS)
+-AM_LDFLAGS = $(XLDFLAGS) $(SECTION_LDFLAGS) $(OPT_LDFLAGS)
++AM_CFLAGS = $(XCFLAGS) -fno-link-libatomic
++AM_CCASFLAGS = $(XCFLAGS) -fno-link-libatomic
++AM_LDFLAGS = $(XLDFLAGS) $(SECTION_LDFLAGS) $(OPT_LDFLAGS) -fno-link-libatomic
+ toolexeclib_LTLIBRARIES = libatomic.la
+ noinst_LTLIBRARIES = libatomic_convenience.la
+ @LIBAT_BUILD_VERSIONED_SHLIB_FALSE@libatomic_version_script = 
+@@ -421,7 +427,7 @@ libatomic_version_info = -version-info $(libtool_VERSION)
+ @ENABLE_DARWIN_AT_RPATH_TRUE@	-Wc,-nodefaultrpaths \
+ @ENABLE_DARWIN_AT_RPATH_TRUE@	-Wl,-rpath,@loader_path
+ libatomic_la_LDFLAGS = $(libatomic_version_info) $(libatomic_version_script) \
+-	$(lt_host_flags) $(libatomic_darwin_rpath)
++	-Wc,-fno-link-libatomic $(lt_host_flags) $(libatomic_darwin_rpath)
+ 
+ libatomic_la_SOURCES = gload.c gstore.c gcas.c gexch.c glfree.c lock.c \
+ 	init.c fenv.c fence.c flag.c $(am__append_5)
+@@ -458,6 +464,7 @@ libatomic_la_LIBADD = $(foreach s,$(SIZES),$(addsuffix \
+ @ARCH_X86_64_TRUE@@HAVE_IFUNC_TRUE@IFUNC_OPTIONS = -mcx16 -mcx16
+ libatomic_convenience_la_SOURCES = $(libatomic_la_SOURCES)
+ libatomic_convenience_la_LIBADD = $(libatomic_la_LIBADD)
++gcc_objdir = $(MULTIBUILDTOP)../../$(host_subdir)/gcc
+ MULTISRCTOP = 
+ MULTIBUILDTOP = 
+ MULTIDIRS = 
+@@ -490,8 +497,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
+ 	    echo ' $(SHELL) ./config.status'; \
+ 	    $(SHELL) ./config.status;; \
+ 	  *) \
+-	    echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \
+-	    cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \
++	    echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles)'; \
++	    cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles);; \
+ 	esac;
+ $(top_srcdir)/../multilib.am $(am__empty):
+ 
+@@ -577,17 +584,23 @@ mostlyclean-compile:
+ distclean-compile:
+ 	-rm -f *.tab.c
+ 
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/atomic_16.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fence.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fenv.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flag.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gcas.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gexch.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/glfree.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gload.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gstore.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/init.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/lock.Plo@am__quote@
++@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/atomic_16.Plo@am__quote@ # am--include-marker
++@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fence.Plo@am__quote@ # am--include-marker
++@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fenv.Plo@am__quote@ # am--include-marker
++@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flag.Plo@am__quote@ # am--include-marker
++@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gcas.Plo@am__quote@ # am--include-marker
++@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gexch.Plo@am__quote@ # am--include-marker
++@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/glfree.Plo@am__quote@ # am--include-marker
++@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gload.Plo@am__quote@ # am--include-marker
++@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gstore.Plo@am__quote@ # am--include-marker
++@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/init.Plo@am__quote@ # am--include-marker
++@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/lock.Plo@am__quote@ # am--include-marker
++
++$(am__depfiles_remade):
++	@$(MKDIR_P) $(@D)
++	@echo '# dummy' >$@-t && $(am__mv) $@-t $@
++
++am--depfiles: $(am__depfiles_remade)
+ 
+ .S.o:
+ @am__fastdepCCAS_TRUE@	$(AM_V_CPPAS)$(CPPASCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
+@@ -791,7 +804,17 @@ clean-am: clean-generic clean-libtool clean-local \
+ 
+ distclean: distclean-recursive
+ 	-rm -f $(am__CONFIG_DISTCLEAN_FILES)
+-	-rm -rf ./$(DEPDIR)
++		-rm -f ./$(DEPDIR)/atomic_16.Plo
++	-rm -f ./$(DEPDIR)/fence.Plo
++	-rm -f ./$(DEPDIR)/fenv.Plo
++	-rm -f ./$(DEPDIR)/flag.Plo
++	-rm -f ./$(DEPDIR)/gcas.Plo
++	-rm -f ./$(DEPDIR)/gexch.Plo
++	-rm -f ./$(DEPDIR)/glfree.Plo
++	-rm -f ./$(DEPDIR)/gload.Plo
++	-rm -f ./$(DEPDIR)/gstore.Plo
++	-rm -f ./$(DEPDIR)/init.Plo
++	-rm -f ./$(DEPDIR)/lock.Plo
+ 	-rm -f Makefile
+ distclean-am: clean-am distclean-compile distclean-generic \
+ 	distclean-hdr distclean-libtool distclean-local distclean-tags
+@@ -839,7 +862,17 @@ installcheck-am:
+ maintainer-clean: maintainer-clean-recursive
+ 	-rm -f $(am__CONFIG_DISTCLEAN_FILES)
+ 	-rm -rf $(top_srcdir)/autom4te.cache
+-	-rm -rf ./$(DEPDIR)
++		-rm -f ./$(DEPDIR)/atomic_16.Plo
++	-rm -f ./$(DEPDIR)/fence.Plo
++	-rm -f ./$(DEPDIR)/fenv.Plo
++	-rm -f ./$(DEPDIR)/flag.Plo
++	-rm -f ./$(DEPDIR)/gcas.Plo
++	-rm -f ./$(DEPDIR)/gexch.Plo
++	-rm -f ./$(DEPDIR)/glfree.Plo
++	-rm -f ./$(DEPDIR)/gload.Plo
++	-rm -f ./$(DEPDIR)/gstore.Plo
++	-rm -f ./$(DEPDIR)/init.Plo
++	-rm -f ./$(DEPDIR)/lock.Plo
+ 	-rm -f Makefile
+ maintainer-clean-am: distclean-am maintainer-clean-generic \
+ 	maintainer-clean-local
+@@ -862,18 +895,19 @@ uninstall-am: uninstall-toolexeclibLTLIBRARIES
+ .MAKE: $(am__recursive_targets) all install-am install-strip
+ 
+ .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am all-local \
+-	am--refresh check check-am clean clean-cscope clean-generic \
+-	clean-libtool clean-local clean-noinstLTLIBRARIES \
+-	clean-toolexeclibLTLIBRARIES cscope cscopelist-am ctags \
+-	ctags-am distclean distclean-compile distclean-generic \
+-	distclean-hdr distclean-libtool distclean-local distclean-tags \
+-	dvi dvi-am html html-am info info-am install install-am \
+-	install-data install-data-am install-dvi install-dvi-am \
+-	install-exec install-exec-am install-exec-local install-html \
+-	install-html-am install-info install-info-am install-man \
+-	install-pdf install-pdf-am install-ps install-ps-am \
+-	install-strip install-toolexeclibLTLIBRARIES installcheck \
+-	installcheck-am installdirs installdirs-am maintainer-clean \
++	am--depfiles am--refresh check check-am clean clean-cscope \
++	clean-generic clean-libtool clean-local \
++	clean-noinstLTLIBRARIES clean-toolexeclibLTLIBRARIES cscope \
++	cscopelist-am ctags ctags-am distclean distclean-compile \
++	distclean-generic distclean-hdr distclean-libtool \
++	distclean-local distclean-tags dvi dvi-am html html-am info \
++	info-am install install-am install-data install-data-am \
++	install-dvi install-dvi-am install-exec install-exec-am \
++	install-exec-local install-html install-html-am install-info \
++	install-info-am install-man install-pdf install-pdf-am \
++	install-ps install-ps-am install-strip \
++	install-toolexeclibLTLIBRARIES installcheck installcheck-am \
++	installdirs installdirs-am maintainer-clean \
+ 	maintainer-clean-generic maintainer-clean-local mostlyclean \
+ 	mostlyclean-compile mostlyclean-generic mostlyclean-libtool \
+ 	mostlyclean-local pdf pdf-am ps ps-am tags tags-am uninstall \
+@@ -901,6 +935,9 @@ vpath % $(strip $(search_path))
+ # makefile fragments to avoid broken *.Ppo getting included into the Makefile
+ # when it is reloaded during the build of all-multi.
+ all-multi: $(libatomic_la_LIBADD)
++all: all-multi libatomic.la
++	$(INSTALL_DATA) .libs/libatomic.a $(gcc_objdir)/
++	chmod 644 $(gcc_objdir)/libatomic.a
+ 
+ # target overrides
+ -include $(tmake_file)
+diff --git a/libatomic/aclocal.m4 b/libatomic/aclocal.m4
+index 80e24219d7d1..4bef515c0f27 100644
+--- a/libatomic/aclocal.m4
++++ b/libatomic/aclocal.m4
+@@ -1,6 +1,6 @@
+-# generated automatically by aclocal 1.15.1 -*- Autoconf -*-
++# generated automatically by aclocal 1.16.1 -*- Autoconf -*-
+ 
+-# Copyright (C) 1996-2017 Free Software Foundation, Inc.
++# Copyright (C) 1996-2018 Free Software Foundation, Inc.
+ 
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -20,7 +20,7 @@ You have another version of autoconf.  It may work, but is not guaranteed to.
+ If you have problems, you may need to regenerate the build system entirely.
+ To do so, use the procedure documented by the package, typically 'autoreconf'.])])
+ 
+-# Copyright (C) 2002-2017 Free Software Foundation, Inc.
++# Copyright (C) 2002-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -32,10 +32,10 @@ To do so, use the procedure documented by the package, typically 'autoreconf'.])
+ # generated from the m4 files accompanying Automake X.Y.
+ # (This private macro should not be called outside this file.)
+ AC_DEFUN([AM_AUTOMAKE_VERSION],
+-[am__api_version='1.15'
++[am__api_version='1.16'
+ dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to
+ dnl require some minimum version.  Point them to the right macro.
+-m4_if([$1], [1.15.1], [],
++m4_if([$1], [1.16.1], [],
+       [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl
+ ])
+ 
+@@ -51,14 +51,14 @@ m4_define([_AM_AUTOCONF_VERSION], [])
+ # Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced.
+ # This function is AC_REQUIREd by AM_INIT_AUTOMAKE.
+ AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION],
+-[AM_AUTOMAKE_VERSION([1.15.1])dnl
++[AM_AUTOMAKE_VERSION([1.16.1])dnl
+ m4_ifndef([AC_AUTOCONF_VERSION],
+   [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
+ _AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))])
+ 
+ # Figure out how to run the assembler.                      -*- Autoconf -*-
+ 
+-# Copyright (C) 2001-2017 Free Software Foundation, Inc.
++# Copyright (C) 2001-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -78,7 +78,7 @@ _AM_IF_OPTION([no-dependencies],, [_AM_DEPENDENCIES([CCAS])])dnl
+ 
+ # AM_AUX_DIR_EXPAND                                         -*- Autoconf -*-
+ 
+-# Copyright (C) 2001-2017 Free Software Foundation, Inc.
++# Copyright (C) 2001-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -130,7 +130,7 @@ am_aux_dir=`cd "$ac_aux_dir" && pwd`
+ 
+ # AM_CONDITIONAL                                            -*- Autoconf -*-
+ 
+-# Copyright (C) 1997-2017 Free Software Foundation, Inc.
++# Copyright (C) 1997-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -161,7 +161,7 @@ AC_CONFIG_COMMANDS_PRE(
+ Usually this means the macro was only invoked conditionally.]])
+ fi])])
+ 
+-# Copyright (C) 1999-2017 Free Software Foundation, Inc.
++# Copyright (C) 1999-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -352,13 +352,12 @@ _AM_SUBST_NOTMAKE([am__nodep])dnl
+ 
+ # Generate code to set up dependency tracking.              -*- Autoconf -*-
+ 
+-# Copyright (C) 1999-2017 Free Software Foundation, Inc.
++# Copyright (C) 1999-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+ # with or without modifications, as long as this notice is preserved.
+ 
+-
+ # _AM_OUTPUT_DEPENDENCY_COMMANDS
+ # ------------------------------
+ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
+@@ -366,49 +365,41 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
+   # Older Autoconf quotes --file arguments for eval, but not when files
+   # are listed without --file.  Let's play safe and only enable the eval
+   # if we detect the quoting.
+-  case $CONFIG_FILES in
+-  *\'*) eval set x "$CONFIG_FILES" ;;
+-  *)   set x $CONFIG_FILES ;;
+-  esac
++  # TODO: see whether this extra hack can be removed once we start
++  # requiring Autoconf 2.70 or later.
++  AS_CASE([$CONFIG_FILES],
++          [*\'*], [eval set x "$CONFIG_FILES"],
++          [*], [set x $CONFIG_FILES])
+   shift
+-  for mf
++  # Used to flag and report bootstrapping failures.
++  am_rc=0
++  for am_mf
+   do
+     # Strip MF so we end up with the name of the file.
+-    mf=`echo "$mf" | sed -e 's/:.*$//'`
+-    # Check whether this is an Automake generated Makefile or not.
+-    # We used to match only the files named 'Makefile.in', but
+-    # some people rename them; so instead we look at the file content.
+-    # Grep'ing the first line is not enough: some people post-process
+-    # each Makefile.in and add a new line on top of each file to say so.
+-    # Grep'ing the whole file is not good either: AIX grep has a line
++    am_mf=`AS_ECHO(["$am_mf"]) | sed -e 's/:.*$//'`
++    # Check whether this is an Automake generated Makefile which includes
++    # dependency-tracking related rules and includes.
++    # Grep'ing the whole file directly is not great: AIX grep has a line
+     # limit of 2048, but all sed's we know have understand at least 4000.
+-    if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
+-      dirpart=`AS_DIRNAME("$mf")`
+-    else
+-      continue
+-    fi
+-    # Extract the definition of DEPDIR, am__include, and am__quote
+-    # from the Makefile without running 'make'.
+-    DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
+-    test -z "$DEPDIR" && continue
+-    am__include=`sed -n 's/^am__include = //p' < "$mf"`
+-    test -z "$am__include" && continue
+-    am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
+-    # Find all dependency output files, they are included files with
+-    # $(DEPDIR) in their names.  We invoke sed twice because it is the
+-    # simplest approach to changing $(DEPDIR) to its actual value in the
+-    # expansion.
+-    for file in `sed -n "
+-      s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
+-	 sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
+-      # Make sure the directory exists.
+-      test -f "$dirpart/$file" && continue
+-      fdir=`AS_DIRNAME(["$file"])`
+-      AS_MKDIR_P([$dirpart/$fdir])
+-      # echo "creating $dirpart/$file"
+-      echo '# dummy' > "$dirpart/$file"
+-    done
++    sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
++      || continue
++    am_dirpart=`AS_DIRNAME(["$am_mf"])`
++    am_filepart=`AS_BASENAME(["$am_mf"])`
++    AM_RUN_LOG([cd "$am_dirpart" \
++      && sed -e '/# am--include-marker/d' "$am_filepart" \
++        | $MAKE -f - am--depfiles]) || am_rc=$?
+   done
++  if test $am_rc -ne 0; then
++    AC_MSG_FAILURE([Something went wrong bootstrapping makefile fragments
++    for automatic dependency tracking.  Try re-running configure with the
++    '--disable-dependency-tracking' option to at least be able to build
++    the package (albeit without support for automatic dependency tracking).])
++  fi
++  AS_UNSET([am_dirpart])
++  AS_UNSET([am_filepart])
++  AS_UNSET([am_mf])
++  AS_UNSET([am_rc])
++  rm -f conftest-deps.mk
+ }
+ ])# _AM_OUTPUT_DEPENDENCY_COMMANDS
+ 
+@@ -417,18 +408,17 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
+ # -----------------------------
+ # This macro should only be invoked once -- use via AC_REQUIRE.
+ #
+-# This code is only required when automatic dependency tracking
+-# is enabled.  FIXME.  This creates each '.P' file that we will
+-# need in order to bootstrap the dependency handling code.
++# This code is only required when automatic dependency tracking is enabled.
++# This creates each '.Po' and '.Plo' makefile fragment that we'll need in
++# order to bootstrap the dependency handling code.
+ AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],
+ [AC_CONFIG_COMMANDS([depfiles],
+      [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS],
+-     [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"])
+-])
++     [AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"])])
+ 
+ # Do all the work for Automake.                             -*- Autoconf -*-
+ 
+-# Copyright (C) 1996-2017 Free Software Foundation, Inc.
++# Copyright (C) 1996-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -515,8 +505,8 @@ AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl
+ AC_REQUIRE([AC_PROG_MKDIR_P])dnl
+ # For better backward compatibility.  To be removed once Automake 1.9.x
+ # dies out for good.  For more background, see:
+-# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
+-# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
++# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
++# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
+ AC_SUBST([mkdir_p], ['$(MKDIR_P)'])
+ # We need awk for the "check" target (and possibly the TAP driver).  The
+ # system "awk" is bad on some platforms.
+@@ -583,7 +573,7 @@ END
+ Aborting the configuration process, to ensure you take notice of the issue.
+ 
+ You can download and install GNU coreutils to get an 'rm' implementation
+-that behaves properly: <http://www.gnu.org/software/coreutils/>.
++that behaves properly: <https://www.gnu.org/software/coreutils/>.
+ 
+ If you want to complete the configuration process using your problematic
+ 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
+@@ -625,7 +615,7 @@ for _am_header in $config_headers :; do
+ done
+ echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count])
+ 
+-# Copyright (C) 2001-2017 Free Software Foundation, Inc.
++# Copyright (C) 2001-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -649,7 +639,7 @@ AC_SUBST([install_sh])])
+ # Add --enable-maintainer-mode option to configure.         -*- Autoconf -*-
+ # From Jim Meyering
+ 
+-# Copyright (C) 1996-2017 Free Software Foundation, Inc.
++# Copyright (C) 1996-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -684,7 +674,7 @@ AC_MSG_CHECKING([whether to enable maintainer-specific portions of Makefiles])
+ 
+ # Check to see how 'make' treats includes.	            -*- Autoconf -*-
+ 
+-# Copyright (C) 2001-2017 Free Software Foundation, Inc.
++# Copyright (C) 2001-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -692,49 +682,42 @@ AC_MSG_CHECKING([whether to enable maintainer-specific portions of Makefiles])
+ 
+ # AM_MAKE_INCLUDE()
+ # -----------------
+-# Check to see how make treats includes.
++# Check whether make has an 'include' directive that can support all
++# the idioms we need for our automatic dependency tracking code.
+ AC_DEFUN([AM_MAKE_INCLUDE],
+-[am_make=${MAKE-make}
+-cat > confinc << 'END'
++[AC_MSG_CHECKING([whether ${MAKE-make} supports the include directive])
++cat > confinc.mk << 'END'
+ am__doit:
+-	@echo this is the am__doit target
++	@echo this is the am__doit target >confinc.out
+ .PHONY: am__doit
+ END
+-# If we don't find an include directive, just comment out the code.
+-AC_MSG_CHECKING([for style of include used by $am_make])
+ am__include="#"
+ am__quote=
+-_am_result=none
+-# First try GNU make style include.
+-echo "include confinc" > confmf
+-# Ignore all kinds of additional output from 'make'.
+-case `$am_make -s -f confmf 2> /dev/null` in #(
+-*the\ am__doit\ target*)
+-  am__include=include
+-  am__quote=
+-  _am_result=GNU
+-  ;;
+-esac
+-# Now try BSD make style include.
+-if test "$am__include" = "#"; then
+-   echo '.include "confinc"' > confmf
+-   case `$am_make -s -f confmf 2> /dev/null` in #(
+-   *the\ am__doit\ target*)
+-     am__include=.include
+-     am__quote="\""
+-     _am_result=BSD
+-     ;;
+-   esac
+-fi
+-AC_SUBST([am__include])
+-AC_SUBST([am__quote])
+-AC_MSG_RESULT([$_am_result])
+-rm -f confinc confmf
+-])
++# BSD make does it like this.
++echo '.include "confinc.mk" # ignored' > confmf.BSD
++# Other make implementations (GNU, Solaris 10, AIX) do it like this.
++echo 'include confinc.mk # ignored' > confmf.GNU
++_am_result=no
++for s in GNU BSD; do
++  AM_RUN_LOG([${MAKE-make} -f confmf.$s && cat confinc.out])
++  AS_CASE([$?:`cat confinc.out 2>/dev/null`],
++      ['0:this is the am__doit target'],
++      [AS_CASE([$s],
++          [BSD], [am__include='.include' am__quote='"'],
++          [am__include='include' am__quote=''])])
++  if test "$am__include" != "#"; then
++    _am_result="yes ($s style)"
++    break
++  fi
++done
++rm -f confinc.* confmf.*
++AC_MSG_RESULT([${_am_result}])
++AC_SUBST([am__include])])
++AC_SUBST([am__quote])])
+ 
+ # Fake the existence of programs that GNU maintainers use.  -*- Autoconf -*-
+ 
+-# Copyright (C) 1997-2017 Free Software Foundation, Inc.
++# Copyright (C) 1997-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -773,7 +756,7 @@ fi
+ 
+ # Helper functions for option handling.                     -*- Autoconf -*-
+ 
+-# Copyright (C) 2001-2017 Free Software Foundation, Inc.
++# Copyright (C) 2001-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -802,7 +785,7 @@ AC_DEFUN([_AM_SET_OPTIONS],
+ AC_DEFUN([_AM_IF_OPTION],
+ [m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])])
+ 
+-# Copyright (C) 1999-2017 Free Software Foundation, Inc.
++# Copyright (C) 1999-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -849,7 +832,7 @@ AC_LANG_POP([C])])
+ # For backward compatibility.
+ AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])])
+ 
+-# Copyright (C) 2001-2017 Free Software Foundation, Inc.
++# Copyright (C) 2001-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -868,7 +851,7 @@ AC_DEFUN([AM_RUN_LOG],
+ 
+ # Check to make sure that the build environment is sane.    -*- Autoconf -*-
+ 
+-# Copyright (C) 1996-2017 Free Software Foundation, Inc.
++# Copyright (C) 1996-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -949,7 +932,7 @@ AC_CONFIG_COMMANDS_PRE(
+ rm -f conftest.file
+ ])
+ 
+-# Copyright (C) 2009-2017 Free Software Foundation, Inc.
++# Copyright (C) 2009-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -1009,7 +992,7 @@ AC_SUBST([AM_BACKSLASH])dnl
+ _AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl
+ ])
+ 
+-# Copyright (C) 2001-2017 Free Software Foundation, Inc.
++# Copyright (C) 2001-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -1037,7 +1020,7 @@ fi
+ INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s"
+ AC_SUBST([INSTALL_STRIP_PROGRAM])])
+ 
+-# Copyright (C) 2006-2017 Free Software Foundation, Inc.
++# Copyright (C) 2006-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -1056,7 +1039,7 @@ AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)])
+ 
+ # Check how to create a tarball.                            -*- Autoconf -*-
+ 
+-# Copyright (C) 2004-2017 Free Software Foundation, Inc.
++# Copyright (C) 2004-2018 Free Software Foundation, Inc.
+ #
+ # This file is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+diff --git a/libatomic/configure b/libatomic/configure
+index d579bab96f86..d14a412ae164 100755
+--- a/libatomic/configure
++++ b/libatomic/configure
+@@ -698,7 +698,6 @@ am__nodep
+ AMDEPBACKSLASH
+ AMDEP_FALSE
+ AMDEP_TRUE
+-am__quote
+ am__include
+ DEPDIR
+ OBJEXT
+@@ -706,8 +705,8 @@ EXEEXT
+ ac_ct_CC
+ CPPFLAGS
+ LDFLAGS
+-CFLAGS
+ CC
++CFLAGS
+ toolexeclibdir
+ toolexecdir
+ multi_basedir
+@@ -771,6 +770,7 @@ infodir
+ docdir
+ oldincludedir
+ includedir
++runstatedir
+ localstatedir
+ sharedstatedir
+ sysconfdir
+@@ -789,7 +789,8 @@ PACKAGE_VERSION
+ PACKAGE_TARNAME
+ PACKAGE_NAME
+ PATH_SEPARATOR
+-SHELL'
++SHELL
++am__quote'
+ ac_subst_files=''
+ ac_user_opts='
+ enable_option_checking
+@@ -855,6 +856,7 @@ datadir='${datarootdir}'
+ sysconfdir='${prefix}/etc'
+ sharedstatedir='${prefix}/com'
+ localstatedir='${prefix}/var'
++runstatedir='${localstatedir}/run'
+ includedir='${prefix}/include'
+ oldincludedir='/usr/include'
+ docdir='${datarootdir}/doc/${PACKAGE_TARNAME}'
+@@ -1107,6 +1109,15 @@ do
+   | -silent | --silent | --silen | --sile | --sil)
+     silent=yes ;;
+ 
++  -runstatedir | --runstatedir | --runstatedi | --runstated \
++  | --runstate | --runstat | --runsta | --runst | --runs \
++  | --run | --ru | --r)
++    ac_prev=runstatedir ;;
++  -runstatedir=* | --runstatedir=* | --runstatedi=* | --runstated=* \
++  | --runstate=* | --runstat=* | --runsta=* | --runst=* | --runs=* \
++  | --run=* | --ru=* | --r=*)
++    runstatedir=$ac_optarg ;;
++
+   -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb)
+     ac_prev=sbindir ;;
+   -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \
+@@ -1244,7 +1255,7 @@ fi
+ for ac_var in	exec_prefix prefix bindir sbindir libexecdir datarootdir \
+ 		datadir sysconfdir sharedstatedir localstatedir includedir \
+ 		oldincludedir docdir infodir htmldir dvidir pdfdir psdir \
+-		libdir localedir mandir
++		libdir localedir mandir runstatedir
+ do
+   eval ac_val=\$$ac_var
+   # Remove trailing slashes.
+@@ -1397,6 +1408,7 @@ Fine tuning of the installation directories:
+   --sysconfdir=DIR        read-only single-machine data [PREFIX/etc]
+   --sharedstatedir=DIR    modifiable architecture-independent data [PREFIX/com]
+   --localstatedir=DIR     modifiable single-machine data [PREFIX/var]
++  --runstatedir=DIR       modifiable per-process data [LOCALSTATEDIR/run]
+   --libdir=DIR            object code libraries [EPREFIX/lib]
+   --includedir=DIR        C header files [PREFIX/include]
+   --oldincludedir=DIR     C header files for non-gcc [/usr/include]
+@@ -2739,7 +2751,7 @@ target_alias=${target_alias-$host_alias}
+ #  -Wall:  turns on all automake warnings...
+ #  -Wno-portability:  ...except this one, since GNU make is required.
+ #  -Wno-override: ... and this one, since we do want this in testsuite.
+-am__api_version='1.15'
++am__api_version='1.16'
+ 
+ # Find a good install program.  We prefer a C program (faster),
+ # so one script is as good as another.  But avoid the broken or
+@@ -3255,8 +3267,8 @@ MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"}
+ 
+ # For better backward compatibility.  To be removed once Automake 1.9.x
+ # dies out for good.  For more background, see:
+-# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
+-# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
++# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
++# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
+ mkdir_p='$(MKDIR_P)'
+ 
+ # We need awk for the "check" target (and possibly the TAP driver).  The
+@@ -3307,7 +3319,7 @@ END
+ Aborting the configuration process, to ensure you take notice of the issue.
+ 
+ You can download and install GNU coreutils to get an 'rm' implementation
+-that behaves properly: <http://www.gnu.org/software/coreutils/>.
++that behaves properly: <https://www.gnu.org/software/coreutils/>.
+ 
+ If you want to complete the configuration process using your problematic
+ 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
+@@ -3409,6 +3421,8 @@ esac
+ 
+ 
+ 
++CFLAGS="$CFLAGS -fno-link-libatomic"
++
+ # Check the compiler.
+ # The same as in boehm-gc and libstdc++. Have to borrow it from there.
+ # We must force CC to /not/ be precious variables; otherwise
+@@ -4268,45 +4282,45 @@ DEPDIR="${am__leading_dot}deps"
+ 
+ ac_config_commands="$ac_config_commands depfiles"
+ 
+-
+-am_make=${MAKE-make}
+-cat > confinc << 'END'
++{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} supports the include directive" >&5
++$as_echo_n "checking whether ${MAKE-make} supports the include directive... " >&6; }
++cat > confinc.mk << 'END'
+ am__doit:
+-	@echo this is the am__doit target
++	@echo this is the am__doit target >confinc.out
+ .PHONY: am__doit
+ END
+-# If we don't find an include directive, just comment out the code.
+-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5
+-$as_echo_n "checking for style of include used by $am_make... " >&6; }
+ am__include="#"
+ am__quote=
+-_am_result=none
+-# First try GNU make style include.
+-echo "include confinc" > confmf
+-# Ignore all kinds of additional output from 'make'.
+-case `$am_make -s -f confmf 2> /dev/null` in #(
+-*the\ am__doit\ target*)
+-  am__include=include
+-  am__quote=
+-  _am_result=GNU
+-  ;;
+-esac
+-# Now try BSD make style include.
+-if test "$am__include" = "#"; then
+-   echo '.include "confinc"' > confmf
+-   case `$am_make -s -f confmf 2> /dev/null` in #(
+-   *the\ am__doit\ target*)
+-     am__include=.include
+-     am__quote="\""
+-     _am_result=BSD
++# BSD make does it like this.
++echo '.include "confinc.mk" # ignored' > confmf.BSD
++# Other make implementations (GNU, Solaris 10, AIX) do it like this.
++echo 'include confinc.mk # ignored' > confmf.GNU
++_am_result=no
++for s in GNU BSD; do
++  { echo "$as_me:$LINENO: ${MAKE-make} -f confmf.$s && cat confinc.out" >&5
++   (${MAKE-make} -f confmf.$s && cat confinc.out) >&5 2>&5
++   ac_status=$?
++   echo "$as_me:$LINENO: \$? = $ac_status" >&5
++   (exit $ac_status); }
++  case $?:`cat confinc.out 2>/dev/null` in #(
++  '0:this is the am__doit target') :
++    case $s in #(
++  BSD) :
++    am__include='.include' am__quote='"' ;; #(
++  *) :
++    am__include='include' am__quote='' ;;
++esac ;; #(
++  *) :
+      ;;
+-   esac
+-fi
+-
+-
+-{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5
+-$as_echo "$_am_result" >&6; }
+-rm -f confinc confmf
++esac
++  if test "$am__include" != "#"; then
++    _am_result="yes ($s style)"
++    break
++  fi
++done
++rm -f confinc.* confmf.*
++{ $as_echo "$as_me:${as_lineno-$LINENO}: result: ${_am_result}" >&5
++$as_echo "${_am_result}" >&6; }
+ 
+ # Check whether --enable-dependency-tracking was given.
+ if test "${enable_dependency_tracking+set}" = set; then :
+@@ -4591,8 +4605,6 @@ fi
+ 
+ 
+ 
+-
+-
+ # In order to override CFLAGS_FOR_TARGET, all of our special flags go
+ # in XCFLAGS.  But we need them in CFLAGS during configury.  So put them
+ # in both places for now and restore CFLAGS at the end of config.
+@@ -11456,7 +11468,7 @@ else
+   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
+   lt_status=$lt_dlunknown
+   cat > conftest.$ac_ext <<_LT_EOF
+-#line 11459 "configure"
++#line 11471 "configure"
+ #include "confdefs.h"
+ 
+ #if HAVE_DLFCN_H
+@@ -11562,7 +11574,7 @@ else
+   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
+   lt_status=$lt_dlunknown
+   cat > conftest.$ac_ext <<_LT_EOF
+-#line 11565 "configure"
++#line 11577 "configure"
+ #include "confdefs.h"
+ 
+ #if HAVE_DLFCN_H
+@@ -11929,6 +11941,7 @@ ac_compiler_gnu=$ac_cv_c_compiler_gnu
+     ;;
+ esac
+ 
++SYSROOT_CFLAGS_FOR_TARGET="$SYSROOT_CFLAGS_FOR_TARGET -fno-link-libatomic"
+ 
+ 
+ # Get target configury.
+@@ -14994,6 +15007,8 @@ rm -f core conftest.err conftest.$ac_objext \
+   ;;
+ esac
+ 
++CFLAGS="$CFLAGS -fno-link-libatomic"
++
+ # See what sort of export controls are available.
+ 
+   { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the target supports hidden visibility" >&5
+@@ -15753,12 +15768,16 @@ fi
+ 
+ XCFLAGS="$XCFLAGS $CET_FLAGS"
+ 
+-XCFLAGS="$XCFLAGS $XPCFLAGS"
++XCFLAGS="$XCFLAGS $XPCFLAGS -fno-link-libatomic"
++XLDFLAGS="$XLDFLAGS -fno-link-libatomic"
++
++
+ 
+ 
+ 
+ 
+ 
++LDFLAGS="$LDFLAGS -fno-link-libatomic"
+ 
+ 
+ # Conditionalize the makefile for this target machine.
+@@ -16620,7 +16639,7 @@ CC="$CC"
+ CXX="$CXX"
+ GFORTRAN="$GFORTRAN"
+ GDC="$GDC"
+-AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"
++AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"
+ 
+ 
+ # The HP-UX ksh and POSIX shell print the target directory to stdout
+@@ -17523,29 +17542,35 @@ esac ;;
+   # Older Autoconf quotes --file arguments for eval, but not when files
+   # are listed without --file.  Let's play safe and only enable the eval
+   # if we detect the quoting.
+-  case $CONFIG_FILES in
+-  *\'*) eval set x "$CONFIG_FILES" ;;
+-  *)   set x $CONFIG_FILES ;;
+-  esac
++  # TODO: see whether this extra hack can be removed once we start
++  # requiring Autoconf 2.70 or later.
++  case $CONFIG_FILES in #(
++  *\'*) :
++    eval set x "$CONFIG_FILES" ;; #(
++  *) :
++    set x $CONFIG_FILES ;; #(
++  *) :
++     ;;
++esac
+   shift
+-  for mf
++  # Used to flag and report bootstrapping failures.
++  am_rc=0
++  for am_mf
+   do
+     # Strip MF so we end up with the name of the file.
+-    mf=`echo "$mf" | sed -e 's/:.*$//'`
+-    # Check whether this is an Automake generated Makefile or not.
+-    # We used to match only the files named 'Makefile.in', but
+-    # some people rename them; so instead we look at the file content.
+-    # Grep'ing the first line is not enough: some people post-process
+-    # each Makefile.in and add a new line on top of each file to say so.
+-    # Grep'ing the whole file is not good either: AIX grep has a line
++    am_mf=`$as_echo "$am_mf" | sed -e 's/:.*$//'`
++    # Check whether this is an Automake generated Makefile which includes
++    # dependency-tracking related rules and includes.
++    # Grep'ing the whole file directly is not great: AIX grep has a line
+     # limit of 2048, but all sed's we know have understand at least 4000.
+-    if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
+-      dirpart=`$as_dirname -- "$mf" ||
+-$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
+-	 X"$mf" : 'X\(//\)[^/]' \| \
+-	 X"$mf" : 'X\(//\)$' \| \
+-	 X"$mf" : 'X\(/\)' \| . 2>/dev/null ||
+-$as_echo X"$mf" |
++    sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
++      || continue
++    am_dirpart=`$as_dirname -- "$am_mf" ||
++$as_expr X"$am_mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
++	 X"$am_mf" : 'X\(//\)[^/]' \| \
++	 X"$am_mf" : 'X\(//\)$' \| \
++	 X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
++$as_echo X"$am_mf" |
+     sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
+ 	    s//\1/
+ 	    q
+@@ -17563,53 +17588,48 @@ $as_echo X"$mf" |
+ 	    q
+ 	  }
+ 	  s/.*/./; q'`
+-    else
+-      continue
+-    fi
+-    # Extract the definition of DEPDIR, am__include, and am__quote
+-    # from the Makefile without running 'make'.
+-    DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
+-    test -z "$DEPDIR" && continue
+-    am__include=`sed -n 's/^am__include = //p' < "$mf"`
+-    test -z "$am__include" && continue
+-    am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
+-    # Find all dependency output files, they are included files with
+-    # $(DEPDIR) in their names.  We invoke sed twice because it is the
+-    # simplest approach to changing $(DEPDIR) to its actual value in the
+-    # expansion.
+-    for file in `sed -n "
+-      s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
+-	 sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
+-      # Make sure the directory exists.
+-      test -f "$dirpart/$file" && continue
+-      fdir=`$as_dirname -- "$file" ||
+-$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
+-	 X"$file" : 'X\(//\)[^/]' \| \
+-	 X"$file" : 'X\(//\)$' \| \
+-	 X"$file" : 'X\(/\)' \| . 2>/dev/null ||
+-$as_echo X"$file" |
+-    sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
+-	    s//\1/
+-	    q
+-	  }
+-	  /^X\(\/\/\)[^/].*/{
++    am_filepart=`$as_basename -- "$am_mf" ||
++$as_expr X/"$am_mf" : '.*/\([^/][^/]*\)/*$' \| \
++	 X"$am_mf" : 'X\(//\)$' \| \
++	 X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
++$as_echo X/"$am_mf" |
++    sed '/^.*\/\([^/][^/]*\)\/*$/{
+ 	    s//\1/
+ 	    q
+ 	  }
+-	  /^X\(\/\/\)$/{
++	  /^X\/\(\/\/\)$/{
+ 	    s//\1/
+ 	    q
+ 	  }
+-	  /^X\(\/\).*/{
++	  /^X\/\(\/\).*/{
+ 	    s//\1/
+ 	    q
+ 	  }
+ 	  s/.*/./; q'`
+-      as_dir=$dirpart/$fdir; as_fn_mkdir_p
+-      # echo "creating $dirpart/$file"
+-      echo '# dummy' > "$dirpart/$file"
+-    done
++    { echo "$as_me:$LINENO: cd "$am_dirpart" \
++      && sed -e '/# am--include-marker/d' "$am_filepart" \
++        | $MAKE -f - am--depfiles" >&5
++   (cd "$am_dirpart" \
++      && sed -e '/# am--include-marker/d' "$am_filepart" \
++        | $MAKE -f - am--depfiles) >&5 2>&5
++   ac_status=$?
++   echo "$as_me:$LINENO: \$? = $ac_status" >&5
++   (exit $ac_status); } || am_rc=$?
+   done
++  if test $am_rc -ne 0; then
++    { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5
++$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
++as_fn_error $? "Something went wrong bootstrapping makefile fragments
++    for automatic dependency tracking.  Try re-running configure with the
++    '--disable-dependency-tracking' option to at least be able to build
++    the package (albeit without support for automatic dependency tracking).
++See \`config.log' for more details" "$LINENO" 5; }
++  fi
++  { am_dirpart=; unset am_dirpart;}
++  { am_filepart=; unset am_filepart;}
++  { am_mf=; unset am_mf;}
++  { am_rc=; unset am_rc;}
++  rm -f conftest-deps.mk
+ }
+  ;;
+     "libtool":C)
+diff --git a/libatomic/configure.ac b/libatomic/configure.ac
+index aafae71028d2..3178f2eefea2 100644
+--- a/libatomic/configure.ac
++++ b/libatomic/configure.ac
+@@ -123,6 +123,8 @@ esac
+ AC_SUBST(toolexecdir)
+ AC_SUBST(toolexeclibdir)
+ 
++CFLAGS="$CFLAGS -fno-link-libatomic"
++AC_SUBST(CFLAGS)
+ # Check the compiler.
+ # The same as in boehm-gc and libstdc++. Have to borrow it from there.
+ # We must force CC to /not/ be precious variables; otherwise
+@@ -135,8 +137,6 @@ AC_PROG_CC
+ AM_PROG_AS
+ m4_rename_force([real_PRECIOUS],[_AC_ARG_VAR_PRECIOUS])
+ 
+-AC_SUBST(CFLAGS)
+-
+ # In order to override CFLAGS_FOR_TARGET, all of our special flags go
+ # in XCFLAGS.  But we need them in CFLAGS during configury.  So put them
+ # in both places for now and restore CFLAGS at the end of config.
+@@ -172,6 +172,7 @@ case "$target" in
+     ;;
+ esac
+ 
++SYSROOT_CFLAGS_FOR_TARGET="$SYSROOT_CFLAGS_FOR_TARGET -fno-link-libatomic"
+ AC_SUBST(SYSROOT_CFLAGS_FOR_TARGET)
+ 
+ # Get target configury.
+@@ -239,6 +240,8 @@ case " $config_path " in
+   ;;
+ esac
+ 
++CFLAGS="$CFLAGS -fno-link-libatomic"
++
+ # See what sort of export controls are available.
+ LIBAT_CHECK_ATTRIBUTE_VISIBILITY
+ LIBAT_CHECK_ATTRIBUTE_DLLEXPORT
+@@ -266,7 +269,8 @@ AS_IF([test "x$enable_werror" != "xno" && test "x$GCC" = "xyes"],
+ GCC_CET_FLAGS(CET_FLAGS)
+ XCFLAGS="$XCFLAGS $CET_FLAGS"
+ 
+-XCFLAGS="$XCFLAGS $XPCFLAGS"
++XCFLAGS="$XCFLAGS $XPCFLAGS -fno-link-libatomic"
++XLDFLAGS="$XLDFLAGS -fno-link-libatomic"
+ 
+ AC_SUBST(config_path)
+ AC_SUBST(XCFLAGS)
+@@ -274,6 +278,9 @@ AC_SUBST(XLDFLAGS)
+ AC_SUBST(LIBS)
+ AC_SUBST(SIZES)
+ 
++LDFLAGS="$LDFLAGS -fno-link-libatomic"
++AC_SUBST(LDFLAGS)
++
+ # Conditionalize the makefile for this target machine.
+ tmake_file_=
+ for f in ${tmake_file}
+diff --git a/libatomic/testsuite/Makefile.in b/libatomic/testsuite/Makefile.in
+index 247268f19490..3974ce8fe9f4 100644
+--- a/libatomic/testsuite/Makefile.in
++++ b/libatomic/testsuite/Makefile.in
+@@ -1,7 +1,7 @@
+-# Makefile.in generated by automake 1.15.1 from Makefile.am.
++# Makefile.in generated by automake 1.16.1 from Makefile.am.
+ # @configure_input@
+ 
+-# Copyright (C) 1994-2017 Free Software Foundation, Inc.
++# Copyright (C) 1994-2018 Free Software Foundation, Inc.
+ 
+ # This Makefile.in is free software; the Free Software Foundation
+ # gives unlimited permission to copy and/or distribute it,
+@@ -253,6 +253,7 @@ pdfdir = @pdfdir@
+ prefix = @prefix@
+ program_transform_name = @program_transform_name@
+ psdir = @psdir@
++runstatedir = @runstatedir@
+ sbindir = @sbindir@
+ sharedstatedir = @sharedstatedir@
+ srcdir = @srcdir@
+@@ -300,8 +301,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
+ 	  *config.status*) \
+ 	    cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
+ 	  *) \
+-	    echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
+-	    cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
++	    echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \
++	    cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \
+ 	esac;
+ 
+ $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
+@@ -332,7 +333,7 @@ check-DEJAGNU: site.exp
+ 	EXPECT=$(EXPECT); export EXPECT; \
+ 	if $(SHELL) -c "$(RUNTEST) --version" > /dev/null 2>&1; then \
+ 	  exit_status=0; l='$(DEJATOOL)'; for tool in $$l; do \
+-	    if $(RUNTEST) $(AM_RUNTESTFLAGS) $(RUNTESTDEFAULTFLAGS) $(RUNTESTFLAGS); \
++	    if $(RUNTEST) $(RUNTESTDEFAULTFLAGS) $(AM_RUNTESTFLAGS) $(RUNTESTFLAGS); \
+ 	    then :; else exit_status=1; fi; \
+ 	  done; \
+ 	else echo "WARNING: could not find '$(RUNTEST)'" 1>&2; :;\
+
+base-commit: 451ff5b58f7c5958f8341160343680262944a63f
+prerequisite-patch-id: cca034489e37f362f6ff4ff1aba0258270153a6a
+prerequisite-patch-id: dcb0315887787c40fae21980c53d20d0b6e234b7
+-- 
+2.47.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index ea310c3..bc29883 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+37	????
+
+	+ 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
+
 36	5 January 2025
 
 	- 73_all_PR117629-c-special-case-some-bool-errors-with-C23.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-06  4:13 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-06  4:13 UTC (permalink / raw
  To: gentoo-commits
commit:     3b46d9416aa28317356af1934a469511433d48c1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  6 04:10:28 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan  6 04:10:28 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=3b46d941
15.0.0: fix crash with -fno-elide-constructors
Bug: https://gcc.gnu.org/PR118199
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...GET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch | 92 ++++++++++++++++++++++
 15.0.0/gentoo/README.history                       |  1 +
 2 files changed, 93 insertions(+)
diff --git a/15.0.0/gentoo/81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch b/15.0.0/gentoo/81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
new file mode 100644
index 0000000..a50765c
--- /dev/null
+++ b/15.0.0/gentoo/81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
@@ -0,0 +1,92 @@
+From 403c57a863a48014db8124cfe84cfbfd8001c084 Mon Sep 17 00:00:00 2001
+Message-ID: <403c57a863a48014db8124cfe84cfbfd8001c084.1736136592.git.sam@gentoo.org>
+From: Simon Martin <simon@nasilyan.com>
+Date: Sun, 5 Jan 2025 20:01:26 +0000
+Subject: [PATCH] c++: Clear TARGET_EXPR_ELIDING_P when forced to use a copy
+ constructor due to __no_unique_address__ [PR118199]
+
+We currently fail with a checking assert upon the following valid code
+when using -fno-elide-constructors
+
+=== cut here ===
+struct d { ~d(); };
+d &b();
+struct f {
+  [[__no_unique_address__]] d e;
+};
+struct h : f  {
+  h() : f{b()} {}
+} i;
+=== cut here ===
+
+The problem is that split_nonconstant_init_1 detects that it cannot
+elide the copy constructor due to __no_unique_address__ but does not
+clear TARGET_EXPR_ELIDING_P, and due to -fno-elide-constructors, we trip
+on a checking assert in cp_gimplify_expr.
+
+This patch fixes this by making sure that we clear TARGET_EXPR_ELIDING_P
+if we determine that we have to keep the copy constructor due to
+__no_unique_address__. An alternative would be to just check for
+elide_constructors in that assert, but I think it'd lose most of its
+value if we did so.
+
+Successfully tested on x86_64-pc-linux-gnu.
+
+	PR c++/118199
+
+gcc/cp/ChangeLog:
+
+	* typeck2.cc (split_nonconstant_init_1): Clear
+	TARGET_EXPR_ELIDING_P if we need to use a copy constructor
+	because of __no_unique_address__.
+
+gcc/testsuite/ChangeLog:
+
+* g++.dg/init/no-elide3.C: New test.
+---
+ gcc/cp/typeck2.cc                     |  5 +++++
+ gcc/testsuite/g++.dg/init/no-elide3.C | 12 ++++++++++++
+ 2 files changed, 17 insertions(+)
+ create mode 100644 gcc/testsuite/g++.dg/init/no-elide3.C
+
+diff --git a/gcc/cp/typeck2.cc b/gcc/cp/typeck2.cc
+index 381f198d0fe6..f50c5f767bb8 100644
+--- a/gcc/cp/typeck2.cc
++++ b/gcc/cp/typeck2.cc
+@@ -655,6 +655,11 @@ split_nonconstant_init_1 (tree dest, tree init, bool last,
+ 			  && make_safe_copy_elision (sub, value))
+ 			goto build_init;
+ 
++		      if (TREE_CODE (value) == TARGET_EXPR)
++			/* We have to add this constructor, so we will not
++			   elide.  */
++			TARGET_EXPR_ELIDING_P (value) = false;
++
+ 		      tree name = (DECL_FIELD_IS_BASE (field_index)
+ 				   ? base_ctor_identifier
+ 				   : complete_ctor_identifier);
+diff --git a/gcc/testsuite/g++.dg/init/no-elide3.C b/gcc/testsuite/g++.dg/init/no-elide3.C
+new file mode 100644
+index 000000000000..659eb19bc95a
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/init/no-elide3.C
+@@ -0,0 +1,12 @@
++// PR c++/118199
++// { dg-do "compile" { target c++11 } }
++// { dg-options "-fno-elide-constructors" } 
++
++struct d { ~d(); };
++d &b();
++struct f {
++  [[__no_unique_address__]] d e;
++};
++struct h : f  {
++  h() : f{b()} {}
++} i;
+
+base-commit: 451ff5b58f7c5958f8341160343680262944a63f
+prerequisite-patch-id: cca034489e37f362f6ff4ff1aba0258270153a6a
+prerequisite-patch-id: dcb0315887787c40fae21980c53d20d0b6e234b7
+-- 
+2.47.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index bc29883..b49ecdf 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 37	????
 
 	+ 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
+	+ 81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
 
 36	5 January 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-06  4:13 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-06  4:13 UTC (permalink / raw
  To: gentoo-commits
commit:     d4f7cdd99282ba4a78888bf1f6ccdd3b54a570f4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  6 04:11:21 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan  6 04:13:47 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=d4f7cdd9
15.0.0: add inbox links
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/79_all_PR32491-fix-binutils-arm-check.patch               | 2 ++
 .../gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch   | 2 ++
 ..._PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch | 2 ++
 3 files changed, 6 insertions(+)
diff --git a/15.0.0/gentoo/79_all_PR32491-fix-binutils-arm-check.patch b/15.0.0/gentoo/79_all_PR32491-fix-binutils-arm-check.patch
index 7e9b847..290fb53 100644
--- a/15.0.0/gentoo/79_all_PR32491-fix-binutils-arm-check.patch
+++ b/15.0.0/gentoo/79_all_PR32491-fix-binutils-arm-check.patch
@@ -1,3 +1,5 @@
+https://inbox.sourceware.org/gcc-patches/20241227214756.1059146-1-thiago.bauermann@linaro.org/
+
 From 4f033ebeb8efb96f4f164e33d2536d1d18316052 Mon Sep 17 00:00:00 2001
 Message-ID: <4f033ebeb8efb96f4f164e33d2536d1d18316052.1735466357.git.sam@gentoo.org>
 From: Thiago Jung Bauermann <thiago.bauermann@linaro.org>
diff --git a/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch b/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
index 61fdc80..5a3028c 100644
--- a/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
+++ b/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
@@ -1,3 +1,5 @@
+https://inbox.sourceware.org/gcc-patches/IA1PR12MB90310A559B28E87BF456C942CE072@IA1PR12MB9031.namprd12.prod.outlook.com/#t
+
 From 15810d4218a601c42a9f5bf264761c3b2bab37ff Mon Sep 17 00:00:00 2001
 Message-ID: <15810d4218a601c42a9f5bf264761c3b2bab37ff.1736136101.git.sam@gentoo.org>
 From: Prathamesh Kulkarni <prathameshk@nvidia.com>
diff --git a/15.0.0/gentoo/81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch b/15.0.0/gentoo/81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
index a50765c..b22e9e6 100644
--- a/15.0.0/gentoo/81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
+++ b/15.0.0/gentoo/81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
@@ -1,3 +1,5 @@
+https://inbox.sourceware.org/gcc-patches/01020194380ee046-69c328dc-fad4-4f3f-bb9a-a405679b67fb-000000@eu-west-1.amazonses.com/
+
 From 403c57a863a48014db8124cfe84cfbfd8001c084 Mon Sep 17 00:00:00 2001
 Message-ID: <403c57a863a48014db8124cfe84cfbfd8001c084.1736136592.git.sam@gentoo.org>
 From: Simon Martin <simon@nasilyan.com>
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-06  4:13 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-06  4:13 UTC (permalink / raw
  To: gentoo-commits
commit:     69d385f037f98eb238a58176d58aa628a1b2a2f8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  6 04:12:18 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan  6 04:13:47 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=69d385f0
15.0.0: update switch-conversion patch
mjw's change is far smaller and targeted, so switch to that.
Bug: https://gcc.gnu.org/PR118032
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...le-Add-limit-after-which-slower-switchlow.patch | 238 ---------------------
 ...-conversion-don-t-apply-switch-size-limit.patch |  51 +++++
 15.0.0/gentoo/README.history                       |   2 +
 3 files changed, 53 insertions(+), 238 deletions(-)
diff --git a/15.0.0/gentoo/78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch b/15.0.0/gentoo/78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch
deleted file mode 100644
index d7f2c46..0000000
--- a/15.0.0/gentoo/78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch
+++ /dev/null
@@ -1,238 +0,0 @@
-From 7305d9452ae9bfc3ee299a194b103e4a4786b0ee Mon Sep 17 00:00:00 2001
-Message-ID: <7305d9452ae9bfc3ee299a194b103e4a4786b0ee.1734674183.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Fri, 20 Dec 2024 05:56:03 +0000
-Subject: [PATCH] Revert "gimple: Add limit after which slower switchlower algs
- are used [PR117091] [PR117352]"
-
-This reverts commit 56946c801a7cf3a831a11870b7e11ba08bf9bd87.
-
-Bug: https://gcc.gnu.org/PR118032
----
- gcc/doc/invoke.texi           |   3 -
- gcc/params.opt                |   4 --
- gcc/tree-switch-conversion.cc | 112 +++-------------------------------
- gcc/tree-switch-conversion.h  |  18 ------
- 4 files changed, 7 insertions(+), 130 deletions(-)
-
-diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
-index 8ed5536365f7..08ad6b998b79 100644
---- a/gcc/doc/invoke.texi
-+++ b/gcc/doc/invoke.texi
-@@ -16522,9 +16522,6 @@ Switch initialization conversion refuses to create arrays that are
- bigger than @option{switch-conversion-max-branch-ratio} times the number of
- branches in the switch.
- 
--@item switch-lower-slow-alg-max-cases
--Maximum number of cases for slow switch lowering algorithms to be used.
--
- @item max-partial-antic-length
- Maximum length of the partial antic set computed during the tree
- partial redundancy elimination optimization (@option{-ftree-pre}) when
-diff --git a/gcc/params.opt b/gcc/params.opt
-index 1c88d5212c40..5853bf02f9ee 100644
---- a/gcc/params.opt
-+++ b/gcc/params.opt
-@@ -1052,10 +1052,6 @@ Maximum number of instruction distance that a small store forwarded to a larger
- Common Joined UInteger Var(param_switch_conversion_branch_ratio) Init(8) IntegerRange(1, 65536) Param Optimization
- The maximum ratio between array size and switch branches for a switch conversion to take place.
- 
---param=switch-lower-slow-alg-max-cases=
--Common Joined UInteger Var(param_switch_lower_slow_alg_max_cases) Init(1000) IntegerRange(1, 1000000000) Param Optimization
--Maximum number of cases for slow switch lowering algorithms to be used.
--
- -param=modref-max-bases=
- Common Joined UInteger Var(param_modref_max_bases) Init(32) Param Optimization
- Maximum number of bases stored in each modref tree.
-diff --git a/gcc/tree-switch-conversion.cc b/gcc/tree-switch-conversion.cc
-index b98e70cf7d16..3436c2a8b98c 100644
---- a/gcc/tree-switch-conversion.cc
-+++ b/gcc/tree-switch-conversion.cc
-@@ -54,7 +54,6 @@ Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
- #include "tree-cfgcleanup.h"
- #include "hwint.h"
- #include "internal-fn.h"
--#include "diagnostic-core.h"
- 
- /* ??? For lang_hooks.types.type_for_mode, but is there a word_mode
-    type in the GIMPLE type system that is language-independent?  */
-@@ -1642,11 +1641,6 @@ jump_table_cluster::find_jump_tables (vec<cluster *> &clusters)
-     return clusters.copy ();
- 
-   unsigned l = clusters.length ();
--
--  /* Note: l + 1 is the number of cases of the switch.  */
--  if (l + 1 > (unsigned) param_switch_lower_slow_alg_max_cases)
--    return clusters.copy ();
--
-   auto_vec<min_cluster_item> min;
-   min.reserve (l + 1);
- 
-@@ -1777,80 +1771,16 @@ jump_table_cluster::is_beneficial (const vec<cluster *> &,
-   return end - start + 1 >= case_values_threshold ();
- }
- 
--/* Find bit tests of given CLUSTERS, where all members of the vector are of
--   type simple_cluster.  Use a fast algorithm that might not find the optimal
--   solution (minimal number of clusters on the output).  New clusters are
--   returned.
--
--   You should call find_bit_tests () instead of calling this function
--   directly.  */
--
--vec<cluster *>
--bit_test_cluster::find_bit_tests_fast (vec<cluster *> &clusters)
--{
--  unsigned l = clusters.length ();
--  vec<cluster *> output;
--
--  output.create (l);
--
--  /* Look at sliding BITS_PER_WORD sized windows in the switch value space
--     and determine if they are suitable for a bit test cluster.  Worst case
--     this can examine every value BITS_PER_WORD-1 times.  */
--  unsigned k;
--  for (unsigned i = 0; i < l; i += k)
--    {
--      hash_set<basic_block> targets;
--      cluster *start_cluster = clusters[i];
--
--      /* Find the biggest k such that clusters i to i+k-1 can be turned into a
--	 one big bit test cluster.  */
--      k = 0;
--      while (i + k < l)
--	{
--	  cluster *end_cluster = clusters[i + k];
--
--	  /* Does value range fit into the BITS_PER_WORD window?  */
--	  HOST_WIDE_INT w = cluster::get_range (start_cluster->get_low (),
--						end_cluster->get_high ());
--	  if (w == 0 || w > BITS_PER_WORD)
--	    break;
--
--	  /* Check for max # of targets.  */
--	  if (targets.elements () == m_max_case_bit_tests
--	      && !targets.contains (end_cluster->m_case_bb))
--	    break;
--
--	  targets.add (end_cluster->m_case_bb);
--	  k++;
--	}
--
--      if (is_beneficial (k, targets.elements ()))
--	{
--	  output.safe_push (new bit_test_cluster (clusters, i, i + k - 1,
--						  i == 0 && k == l));
--	}
--      else
--	{
--	  output.safe_push (clusters[i]);
--	  /* ??? Might be able to skip more.  */
--	  k = 1;
--	}
--    }
--
--  return output;
--}
--
- /* Find bit tests of given CLUSTERS, where all members of the vector
--   are of type simple_cluster.  Use a slow (quadratic) algorithm that always
--   finds the optimal solution (minimal number of clusters on the output).  New
--   clusters are returned.
--
--   You should call find_bit_tests () instead of calling this function
--   directly.  */
-+   are of type simple_cluster.   MAX_C is the approx max number of cases per
-+   label.  New clusters are returned.  */
- 
- vec<cluster *>
--bit_test_cluster::find_bit_tests_slow (vec<cluster *> &clusters)
-+bit_test_cluster::find_bit_tests (vec<cluster *> &clusters, int max_c)
- {
-+  if (!is_enabled () || max_c == 1)
-+    return clusters.copy ();
-+
-   unsigned l = clusters.length ();
-   auto_vec<min_cluster_item> min;
-   min.reserve (l + 1);
-@@ -1904,25 +1834,6 @@ bit_test_cluster::find_bit_tests_slow (vec<cluster *> &clusters)
-   return output;
- }
- 
--/* Find bit tests of given CLUSTERS, where all members of the vector
--   are of type simple_cluster.  MAX_C is the approx max number of cases per
--   label.  New clusters are returned.  */
--
--vec<cluster *>
--bit_test_cluster::find_bit_tests (vec<cluster *> &clusters, int max_c)
--{
--  if (!is_enabled () || max_c == 1)
--    return clusters.copy ();
--
--  unsigned l = clusters.length ();
--
--  /* Note: l + 1 is the number of cases of the switch.  */
--  if (l + 1 > (unsigned) param_switch_lower_slow_alg_max_cases)
--    return find_bit_tests_fast (clusters);
--  else
--    return find_bit_tests_slow (clusters);
--}
--
- /* Return true when RANGE of case values with UNIQ labels
-    can build a bit test.  */
- 
-@@ -2353,19 +2264,10 @@ switch_decision_tree::analyze_switch_statement ()
- 
-   reset_out_edges_aux (m_switch);
- 
--  if (l > (unsigned) param_switch_lower_slow_alg_max_cases)
--    warning_at (gimple_location (m_switch), OPT_Wdisabled_optimization,
--	       "Using faster switch lowering algorithms. "
--	       "Number of switch cases (%d) exceeds "
--	       "%<--param=switch-lower-slow-alg-max-cases=%d%> limit.",
--	       l, param_switch_lower_slow_alg_max_cases);
--
-   /* Find bit-test clusters.  */
-   vec<cluster *> output = bit_test_cluster::find_bit_tests (clusters, max_c);
- 
--  /* Find jump table clusters.  We are looking for these in the sequences of
--     simple clusters which we didn't manage to convert into bit-test
--     clusters.  */
-+  /* Find jump table clusters.  */
-   vec<cluster *> output2;
-   auto_vec<cluster *> tmp;
-   output2.create (1);
-diff --git a/gcc/tree-switch-conversion.h b/gcc/tree-switch-conversion.h
-index 560620903a86..e6a85fa60258 100644
---- a/gcc/tree-switch-conversion.h
-+++ b/gcc/tree-switch-conversion.h
-@@ -397,24 +397,6 @@ public:
- 	     tree default_label_expr, basic_block default_bb, location_t loc)
-      final override;
- 
--  /* Find bit tests of given CLUSTERS, where all members of the vector are of
--     type simple_cluster.  Use a fast algorithm that might not find the optimal
--     solution (minimal number of clusters on the output).  New clusters are
--     returned.
--
--     You should call find_bit_tests () instead of calling this function
--     directly.  */
--  static vec<cluster *> find_bit_tests_fast (vec<cluster *> &clusters);
--
--  /* Find bit tests of given CLUSTERS, where all members of the vector
--     are of type simple_cluster.  Use a slow (quadratic) algorithm that always
--     finds the optimal solution (minimal number of clusters on the output).  New
--     clusters are returned.
--
--     You should call find_bit_tests () instead of calling this function
--     directly.  */
--  static vec<cluster *> find_bit_tests_slow (vec<cluster *> &clusters);
--
-   /* Find bit tests of given CLUSTERS, where all members of the vector
-      are of type simple_cluster.  New clusters are returned.  */
-   static vec<cluster *> find_bit_tests (vec<cluster *> &clusters, int max_c);
-
-base-commit: b11e85adbfdb02bc7743098d358a5ea362648ca1
--- 
-2.47.1
-
diff --git a/15.0.0/gentoo/78_all_PR118032-tree-switch-conversion-don-t-apply-switch-size-limit.patch b/15.0.0/gentoo/78_all_PR118032-tree-switch-conversion-don-t-apply-switch-size-limit.patch
new file mode 100644
index 0000000..20018ef
--- /dev/null
+++ b/15.0.0/gentoo/78_all_PR118032-tree-switch-conversion-don-t-apply-switch-size-limit.patch
@@ -0,0 +1,51 @@
+https://inbox.sourceware.org/gcc-patches/20250105172539.906393-1-mark@klomp.org/
+
+From 4e8dc9973c98a8b0c5cfe555221dc7dee5d92662 Mon Sep 17 00:00:00 2001
+Message-ID: <4e8dc9973c98a8b0c5cfe555221dc7dee5d92662.1736136715.git.sam@gentoo.org>
+From: Mark Wielaard <mark@klomp.org>
+Date: Sun, 5 Jan 2025 18:25:39 +0100
+Subject: [PATCH] tree-switch-conversion: don't apply switch size limit on jump
+ tables
+
+commit 56946c801a7c ("gimple: Add limit after which slower switchlower
+algs are used [PR117091] [PR117352]") introduced a limit on the number
+of cases of a switch. It also bails out on finding jump tables if the
+switch is too large. This introduces a compile time regression during
+bootstrap. A riscv bootstrap takes hours longer. Particularly
+insn-attrtab.cc will take hours instead of minutes. Fix this by not
+applying the switch size limit on jump tables.
+
+An alternative would be to implement greedy switch clustering for jump
+tables as is done for switch bitmap clustering.
+
+gcc/ChangeLog:
+
+PR tree-optimization/118032
+	* tree-switch-conversion.cc (jump_table_cluster::find_jump_tables):
+	Remove param_switch_lower_slow_alg_max_cases check.
+---
+ gcc/tree-switch-conversion.cc | 4 ----
+ 1 file changed, 4 deletions(-)
+
+diff --git a/gcc/tree-switch-conversion.cc b/gcc/tree-switch-conversion.cc
+index 432970597c97..39a8a893edde 100644
+--- a/gcc/tree-switch-conversion.cc
++++ b/gcc/tree-switch-conversion.cc
+@@ -1643,10 +1643,6 @@ jump_table_cluster::find_jump_tables (vec<cluster *> &clusters)
+ 
+   unsigned l = clusters.length ();
+ 
+-  /* Note: l + 1 is the number of cases of the switch.  */
+-  if (l + 1 > (unsigned) param_switch_lower_slow_alg_max_cases)
+-    return clusters.copy ();
+-
+   auto_vec<min_cluster_item> min;
+   min.reserve (l + 1);
+ 
+
+base-commit: 451ff5b58f7c5958f8341160343680262944a63f
+prerequisite-patch-id: cca034489e37f362f6ff4ff1aba0258270153a6a
+prerequisite-patch-id: dcb0315887787c40fae21980c53d20d0b6e234b7
+-- 
+2.47.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index b49ecdf..412cb40 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,7 @@
 37	????
 
+	- 78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch
+	+ 78_all_PR118032-tree-switch-conversion-don-t-apply-switch-size-limit.patch
 	+ 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
 	+ 81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-06  4:44 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-06  4:44 UTC (permalink / raw
  To: gentoo-commits
commit:     e65480342517f7f8fd1b2c479e4cec882b6a14d7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  6 04:44:36 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan  6 04:44:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=e6548034
Revert "15.0.0: add 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch"
This reverts commit c1ac1ff6f687e8612b003b96a8d768f47c41218a.
It breaks the build w/ multilib libgomp, reported via email.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 1 -
 1 file changed, 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 412cb40..edfaab4 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -2,7 +2,6 @@
 
 	- 78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch
 	+ 78_all_PR118032-tree-switch-conversion-don-t-apply-switch-size-limit.patch
-	+ 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
 	+ 81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
 
 36	5 January 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-06  4:49 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-06  4:49 UTC (permalink / raw
  To: gentoo-commits
commit:     54b0f920268f608ad4e8273e9851e5240ea62e68
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  6 04:49:35 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan  6 04:49:35 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=54b0f920
15.0.0: actually drop libatomic patch for now
Messed up the conflict resolution...
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...358-Enable-automatic-linking-of-libatomic.patch | 1495 --------------------
 1 file changed, 1495 deletions(-)
diff --git a/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch b/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
deleted file mode 100644
index 5a3028c..0000000
--- a/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
+++ /dev/null
@@ -1,1495 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/IA1PR12MB90310A559B28E87BF456C942CE072@IA1PR12MB9031.namprd12.prod.outlook.com/#t
-
-From 15810d4218a601c42a9f5bf264761c3b2bab37ff Mon Sep 17 00:00:00 2001
-Message-ID: <15810d4218a601c42a9f5bf264761c3b2bab37ff.1736136101.git.sam@gentoo.org>
-From: Prathamesh Kulkarni <prathameshk@nvidia.com>
-Date: Sat, 16 Nov 2024 03:44:26 +0000
-Subject: [PATCH] PR81358: Enable automatic linking of libatomic
-
-PR81358: Enable automatic linking of libatomic.
-
-ChangeLog:
-	PR driver/81358
-	* Makefile.def: Add dependencies so libatomic is built before target
-	libraries are configured.
-	* configure.ac: Add libatomic to bootstrap_target_libs.
-	* Makefile.in: Regenerate.
-	* configure: Regenerate.
-
-gcc/ChangeLog:
-	PR driver/81358
-	* common.opt: New option -flink-atomic.
-	* config/gnu-user.h (GNU_USER_TARGET_LINK_GCC_C_SEQUENCE_SPEC): Use
-	LINK_LIBATOMIC_SPEC.
-	* gcc.cc (LINK_LIBATOMIC_SPEC): New macro.
-
-libatomic/ChangeLog:
-	PR driver/81358
-	* Makefile.am: Pass -fno-link-atomic.
-	New rule all.
-	* configure.ac: Pass -fno-link-atomic.
-	* Makefile.in: Regenerate.
-	* aclocal.m4: Regenerate.
-	* configure: Regenerate.
-	* testsuite/Makefile.in: Regenerate.
-
-Signed-off-by: Prathamesh Kulkarni <prathameshk@nvidia.com>
-Co-authored-by: Matthew Malcolmson <mmalcolmson@nvidia.com>
----
- Makefile.def                    |  20 +++
- Makefile.in                     | 112 ++++++++++++++++
- configure                       |  19 ++-
- configure.ac                    |   5 +
- gcc/common.opt                  |   3 +
- gcc/config/gnu-user.h           |   3 +-
- gcc/gcc.cc                      |   7 +
- libatomic/Makefile.am           |  13 +-
- libatomic/Makefile.in           | 107 ++++++++++-----
- libatomic/aclocal.m4            | 191 +++++++++++++--------------
- libatomic/configure             | 224 +++++++++++++++++---------------
- libatomic/configure.ac          |  13 +-
- libatomic/testsuite/Makefile.in |  11 +-
- 13 files changed, 473 insertions(+), 255 deletions(-)
-
-diff --git a/Makefile.def b/Makefile.def
-index 19954e7d7318..90899fa28cf0 100644
---- a/Makefile.def
-+++ b/Makefile.def
-@@ -656,6 +656,26 @@ lang_env_dependencies = { module=libgcc; no_gcc=true; no_c=true; };
- // a dependency on libgcc for native targets to configure.
- lang_env_dependencies = { module=libiberty; no_c=true; };
- 
-+dependencies = { module=configure-target-libbacktrace; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libgloss; on=all-target-libatomic; };
-+dependencies = { module=configure-target-newlib; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libgomp; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libitm; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libstdc++v3; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libsanitizer; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libvtv; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libssp; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libquadmath; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libgfortran; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libffi; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libobjc; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libada; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libgm2; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libgo; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libgrust; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libphobos; on=all-target-libatomic; };
-+dependencies = { module=configure-target-zlib; on=all-target-libatomic; };
-+
- dependencies = { module=configure-target-fastjar; on=configure-target-zlib; };
- dependencies = { module=all-target-fastjar; on=all-target-zlib; };
- dependencies = { module=configure-target-libgo; on=configure-target-libffi; };
-diff --git a/Makefile.in b/Makefile.in
-index 966d60454960..5295929bfa9b 100644
---- a/Makefile.in
-+++ b/Makefile.in
-@@ -68551,6 +68551,66 @@ all-flex: maybe-all-build-bison
- all-flex: maybe-all-m4
- all-flex: maybe-all-build-texinfo
- all-m4: maybe-all-build-texinfo
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
- configure-target-libgo: maybe-configure-target-libffi
- all-target-libgo: maybe-all-target-libffi
- configure-target-libphobos: maybe-configure-target-libbacktrace
-@@ -68678,6 +68738,45 @@ configure-m4: stage_last
- @endif gcc-bootstrap
- 
- @if gcc-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libgloss: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-newlib: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libitm: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libstdc++v3: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libssp: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libquadmath: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libgfortran: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libffi: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libobjc: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libada: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libgm2: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libgo: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
- @unless target-zlib-bootstrap
- configure-target-fastjar: maybe-configure-target-zlib
- @endunless target-zlib-bootstrap
-@@ -68755,6 +68854,19 @@ all-fastjar: maybe-all-libiberty
- all-bison: maybe-all-gettext
- all-flex: maybe-all-gettext
- all-m4: maybe-all-gettext
-+configure-target-libgloss: maybe-all-target-libatomic
-+configure-target-newlib: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libstdc++v3: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
- configure-target-fastjar: maybe-configure-target-zlib
- all-target-fastjar: maybe-all-target-zlib
- configure-target-libgo: maybe-all-target-libstdc++-v3
-diff --git a/configure b/configure
-index 4ae8e1242afa..376898374a29 100755
---- a/configure
-+++ b/configure
-@@ -776,6 +776,7 @@ infodir
- docdir
- oldincludedir
- includedir
-+runstatedir
- localstatedir
- sharedstatedir
- sysconfdir
-@@ -951,6 +952,7 @@ datadir='${datarootdir}'
- sysconfdir='${prefix}/etc'
- sharedstatedir='${prefix}/com'
- localstatedir='${prefix}/var'
-+runstatedir='${localstatedir}/run'
- includedir='${prefix}/include'
- oldincludedir='/usr/include'
- docdir='${datarootdir}/doc/${PACKAGE}'
-@@ -1203,6 +1205,15 @@ do
-   | -silent | --silent | --silen | --sile | --sil)
-     silent=yes ;;
- 
-+  -runstatedir | --runstatedir | --runstatedi | --runstated \
-+  | --runstate | --runstat | --runsta | --runst | --runs \
-+  | --run | --ru | --r)
-+    ac_prev=runstatedir ;;
-+  -runstatedir=* | --runstatedir=* | --runstatedi=* | --runstated=* \
-+  | --runstate=* | --runstat=* | --runsta=* | --runst=* | --runs=* \
-+  | --run=* | --ru=* | --r=*)
-+    runstatedir=$ac_optarg ;;
-+
-   -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb)
-     ac_prev=sbindir ;;
-   -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \
-@@ -1340,7 +1351,7 @@ fi
- for ac_var in	exec_prefix prefix bindir sbindir libexecdir datarootdir \
- 		datadir sysconfdir sharedstatedir localstatedir includedir \
- 		oldincludedir docdir infodir htmldir dvidir pdfdir psdir \
--		libdir localedir mandir
-+		libdir localedir mandir runstatedir
- do
-   eval ac_val=\$$ac_var
-   # Remove trailing slashes.
-@@ -1500,6 +1511,7 @@ Fine tuning of the installation directories:
-   --sysconfdir=DIR        read-only single-machine data [PREFIX/etc]
-   --sharedstatedir=DIR    modifiable architecture-independent data [PREFIX/com]
-   --localstatedir=DIR     modifiable single-machine data [PREFIX/var]
-+  --runstatedir=DIR       modifiable per-process data [LOCALSTATEDIR/run]
-   --libdir=DIR            object code libraries [EPREFIX/lib]
-   --includedir=DIR        C header files [PREFIX/include]
-   --oldincludedir=DIR     C header files for non-gcc [/usr/include]
-@@ -10924,6 +10936,11 @@ if echo " ${target_configdirs} " | grep " libgomp " > /dev/null 2>&1 ; then
-   bootstrap_target_libs=${bootstrap_target_libs}target-libgomp,
- fi
- 
-+# If we are building libatomic, bootstrap it.
-+if echo " ${target_configdirs} " | grep " libatomic " > /dev/null 2>&1 ; then
-+  bootstrap_target_libs=${bootstrap_target_libs}target-libatomic,
-+fi
-+
- # If we are building libsanitizer and $BUILD_CONFIG contains bootstrap-asan
- # or bootstrap-ubsan, bootstrap it.
- if echo " ${target_configdirs} " | grep " libsanitizer " > /dev/null 2>&1; then
-diff --git a/configure.ac b/configure.ac
-index 9a72b2311bdd..c44d84f32ce1 100644
---- a/configure.ac
-+++ b/configure.ac
-@@ -3151,6 +3151,11 @@ if echo " ${target_configdirs} " | grep " libgomp " > /dev/null 2>&1 ; then
-   bootstrap_target_libs=${bootstrap_target_libs}target-libgomp,
- fi
- 
-+# If we are building libatomic, bootstrap it.
-+if echo " ${target_configdirs} " | grep " libatomic " > /dev/null 2>&1 ; then
-+  bootstrap_target_libs=${bootstrap_target_libs}target-libatomic,
-+fi
-+
- # If we are building libsanitizer and $BUILD_CONFIG contains bootstrap-asan
- # or bootstrap-ubsan, bootstrap it.
- if echo " ${target_configdirs} " | grep " libsanitizer " > /dev/null 2>&1; then
-diff --git a/gcc/common.opt b/gcc/common.opt
-index e2ac99df1d0d..cbb6a791c89d 100644
---- a/gcc/common.opt
-+++ b/gcc/common.opt
-@@ -3361,6 +3361,9 @@ Use the Modern linker (MOLD) linker instead of the default linker.
- fuse-linker-plugin
- Common Undocumented Var(flag_use_linker_plugin)
- 
-+flink-libatomic
-+Common Driver Var(flag_link_libatomic) Init(1)
-+
- ; Positive if we should track variables, negative if we should run
- ; the var-tracking pass only to discard debug annotations, zero if
- ; we're not to run it.
-diff --git a/gcc/config/gnu-user.h b/gcc/config/gnu-user.h
-index 4c4e31efa393..151871540e7b 100644
---- a/gcc/config/gnu-user.h
-+++ b/gcc/config/gnu-user.h
-@@ -109,8 +109,9 @@ see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
- #define LINK_EH_SPEC "%{!static|static-pie:--eh-frame-hdr} "
- #endif
- 
-+
- #define GNU_USER_TARGET_LINK_GCC_C_SEQUENCE_SPEC \
--  "%{static|static-pie:--start-group} %G %{!nolibc:%L} \
-+  "%{static|static-pie:--start-group} %G %{!nolibc:" LINK_LIBATOMIC_SPEC "%L} \
-    %{static|static-pie:--end-group}%{!static:%{!static-pie:%G}}"
- 
- #undef LINK_GCC_C_SEQUENCE_SPEC
-diff --git a/gcc/gcc.cc b/gcc/gcc.cc
-index 95b98eaa83cf..815558ab38b1 100644
---- a/gcc/gcc.cc
-+++ b/gcc/gcc.cc
-@@ -980,6 +980,13 @@ proper position among the other output files.  */
- 
- /* Here is the spec for running the linker, after compiling all files.  */
- 
-+#ifdef USE_LD_AS_NEEDED
-+#define LINK_LIBATOMIC_SPEC "%{!fno-link-libatomic:" LD_AS_NEEDED_OPTION \
-+			    " -latomic " LD_NO_AS_NEEDED_OPTION "} "
-+#else
-+#define LINK_LIBATOMIC_SPEC ""
-+#endif
-+
- /* This is overridable by the target in case they need to specify the
-    -lgcc and -lc order specially, yet not require them to override all
-    of LINK_COMMAND_SPEC.  */
-diff --git a/libatomic/Makefile.am b/libatomic/Makefile.am
-index 0f1a71560848..9f83ef6cd913 100644
---- a/libatomic/Makefile.am
-+++ b/libatomic/Makefile.am
-@@ -35,9 +35,9 @@ search_path = $(addprefix $(top_srcdir)/config/, $(config_path)) \
- vpath % $(strip $(search_path))
- 
- DEFAULT_INCLUDES = $(addprefix -I, $(search_path))
--AM_CFLAGS = $(XCFLAGS)
--AM_CCASFLAGS = $(XCFLAGS)
--AM_LDFLAGS = $(XLDFLAGS) $(SECTION_LDFLAGS) $(OPT_LDFLAGS)
-+AM_CFLAGS = $(XCFLAGS) -fno-link-libatomic
-+AM_CCASFLAGS = $(XCFLAGS) -fno-link-libatomic
-+AM_LDFLAGS = $(XLDFLAGS) $(SECTION_LDFLAGS) $(OPT_LDFLAGS) -fno-link-libatomic
- 
- toolexeclib_LTLIBRARIES = libatomic.la
- noinst_LTLIBRARIES = libatomic_convenience.la
-@@ -69,7 +69,7 @@ libatomic_darwin_rpath += -Wl,-rpath,@loader_path
- endif
- 
- libatomic_la_LDFLAGS = $(libatomic_version_info) $(libatomic_version_script) \
--	$(lt_host_flags) $(libatomic_darwin_rpath)
-+	-Wc,-fno-link-libatomic $(lt_host_flags) $(libatomic_darwin_rpath)
- libatomic_la_SOURCES = gload.c gstore.c gcas.c gexch.c glfree.c lock.c init.c \
- 	fenv.c fence.c flag.c
- 
-@@ -162,6 +162,11 @@ libatomic_convenience_la_LIBADD = $(libatomic_la_LIBADD)
- # when it is reloaded during the build of all-multi.
- all-multi: $(libatomic_la_LIBADD)
- 
-+gcc_objdir = $(MULTIBUILDTOP)../../$(host_subdir)/gcc
-+all: all-multi libatomic.la
-+	$(INSTALL_DATA) .libs/libatomic.a $(gcc_objdir)/
-+	chmod 644 $(gcc_objdir)/libatomic.a
-+
- # target overrides
- -include $(tmake_file)
- 
-diff --git a/libatomic/Makefile.in b/libatomic/Makefile.in
-index 9798e7c09e99..62cd5e0a76b3 100644
---- a/libatomic/Makefile.in
-+++ b/libatomic/Makefile.in
-@@ -1,7 +1,7 @@
--# Makefile.in generated by automake 1.15.1 from Makefile.am.
-+# Makefile.in generated by automake 1.16.1 from Makefile.am.
- # @configure_input@
- 
--# Copyright (C) 1994-2017 Free Software Foundation, Inc.
-+# Copyright (C) 1994-2018 Free Software Foundation, Inc.
- 
- # This Makefile.in is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -187,11 +187,16 @@ am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
- am__v_at_0 = @
- am__v_at_1 = 
- depcomp = $(SHELL) $(top_srcdir)/../depcomp
--am__depfiles_maybe = depfiles
-+am__maybe_remake_depfiles = depfiles
-+am__depfiles_remade = ./$(DEPDIR)/atomic_16.Plo ./$(DEPDIR)/fence.Plo \
-+	./$(DEPDIR)/fenv.Plo ./$(DEPDIR)/flag.Plo ./$(DEPDIR)/gcas.Plo \
-+	./$(DEPDIR)/gexch.Plo ./$(DEPDIR)/glfree.Plo \
-+	./$(DEPDIR)/gload.Plo ./$(DEPDIR)/gstore.Plo \
-+	./$(DEPDIR)/init.Plo ./$(DEPDIR)/lock.Plo
- am__mv = mv -f
- CPPASCOMPILE = $(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \
- 	$(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CCASFLAGS) $(CCASFLAGS)
--LTCPPASCOMPILE = $(LIBTOOL) $(AM_V_lt) $(AM_LIBTOOLFLAGS) \
-+LTCPPASCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
- 	$(LIBTOOLFLAGS) --mode=compile $(CCAS) $(DEFS) \
- 	$(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \
- 	$(AM_CCASFLAGS) $(CCASFLAGS)
-@@ -383,6 +388,7 @@ pdfdir = @pdfdir@
- prefix = @prefix@
- program_transform_name = @program_transform_name@
- psdir = @psdir@
-+runstatedir = @runstatedir@
- sbindir = @sbindir@
- sharedstatedir = @sharedstatedir@
- srcdir = @srcdir@
-@@ -405,9 +411,9 @@ search_path = $(addprefix $(top_srcdir)/config/, $(config_path)) \
- 	$(top_srcdir) $(top_builddir)
- 
- DEFAULT_INCLUDES = $(addprefix -I, $(search_path))
--AM_CFLAGS = $(XCFLAGS)
--AM_CCASFLAGS = $(XCFLAGS)
--AM_LDFLAGS = $(XLDFLAGS) $(SECTION_LDFLAGS) $(OPT_LDFLAGS)
-+AM_CFLAGS = $(XCFLAGS) -fno-link-libatomic
-+AM_CCASFLAGS = $(XCFLAGS) -fno-link-libatomic
-+AM_LDFLAGS = $(XLDFLAGS) $(SECTION_LDFLAGS) $(OPT_LDFLAGS) -fno-link-libatomic
- toolexeclib_LTLIBRARIES = libatomic.la
- noinst_LTLIBRARIES = libatomic_convenience.la
- @LIBAT_BUILD_VERSIONED_SHLIB_FALSE@libatomic_version_script = 
-@@ -421,7 +427,7 @@ libatomic_version_info = -version-info $(libtool_VERSION)
- @ENABLE_DARWIN_AT_RPATH_TRUE@	-Wc,-nodefaultrpaths \
- @ENABLE_DARWIN_AT_RPATH_TRUE@	-Wl,-rpath,@loader_path
- libatomic_la_LDFLAGS = $(libatomic_version_info) $(libatomic_version_script) \
--	$(lt_host_flags) $(libatomic_darwin_rpath)
-+	-Wc,-fno-link-libatomic $(lt_host_flags) $(libatomic_darwin_rpath)
- 
- libatomic_la_SOURCES = gload.c gstore.c gcas.c gexch.c glfree.c lock.c \
- 	init.c fenv.c fence.c flag.c $(am__append_5)
-@@ -458,6 +464,7 @@ libatomic_la_LIBADD = $(foreach s,$(SIZES),$(addsuffix \
- @ARCH_X86_64_TRUE@@HAVE_IFUNC_TRUE@IFUNC_OPTIONS = -mcx16 -mcx16
- libatomic_convenience_la_SOURCES = $(libatomic_la_SOURCES)
- libatomic_convenience_la_LIBADD = $(libatomic_la_LIBADD)
-+gcc_objdir = $(MULTIBUILDTOP)../../$(host_subdir)/gcc
- MULTISRCTOP = 
- MULTIBUILDTOP = 
- MULTIDIRS = 
-@@ -490,8 +497,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
- 	    echo ' $(SHELL) ./config.status'; \
- 	    $(SHELL) ./config.status;; \
- 	  *) \
--	    echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \
--	    cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \
-+	    echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles)'; \
-+	    cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles);; \
- 	esac;
- $(top_srcdir)/../multilib.am $(am__empty):
- 
-@@ -577,17 +584,23 @@ mostlyclean-compile:
- distclean-compile:
- 	-rm -f *.tab.c
- 
--@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/atomic_16.Plo@am__quote@
--@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fence.Plo@am__quote@
--@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fenv.Plo@am__quote@
--@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flag.Plo@am__quote@
--@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gcas.Plo@am__quote@
--@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gexch.Plo@am__quote@
--@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/glfree.Plo@am__quote@
--@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gload.Plo@am__quote@
--@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gstore.Plo@am__quote@
--@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/init.Plo@am__quote@
--@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/lock.Plo@am__quote@
-+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/atomic_16.Plo@am__quote@ # am--include-marker
-+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fence.Plo@am__quote@ # am--include-marker
-+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fenv.Plo@am__quote@ # am--include-marker
-+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/flag.Plo@am__quote@ # am--include-marker
-+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gcas.Plo@am__quote@ # am--include-marker
-+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gexch.Plo@am__quote@ # am--include-marker
-+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/glfree.Plo@am__quote@ # am--include-marker
-+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gload.Plo@am__quote@ # am--include-marker
-+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gstore.Plo@am__quote@ # am--include-marker
-+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/init.Plo@am__quote@ # am--include-marker
-+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/lock.Plo@am__quote@ # am--include-marker
-+
-+$(am__depfiles_remade):
-+	@$(MKDIR_P) $(@D)
-+	@echo '# dummy' >$@-t && $(am__mv) $@-t $@
-+
-+am--depfiles: $(am__depfiles_remade)
- 
- .S.o:
- @am__fastdepCCAS_TRUE@	$(AM_V_CPPAS)$(CPPASCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
-@@ -791,7 +804,17 @@ clean-am: clean-generic clean-libtool clean-local \
- 
- distclean: distclean-recursive
- 	-rm -f $(am__CONFIG_DISTCLEAN_FILES)
--	-rm -rf ./$(DEPDIR)
-+		-rm -f ./$(DEPDIR)/atomic_16.Plo
-+	-rm -f ./$(DEPDIR)/fence.Plo
-+	-rm -f ./$(DEPDIR)/fenv.Plo
-+	-rm -f ./$(DEPDIR)/flag.Plo
-+	-rm -f ./$(DEPDIR)/gcas.Plo
-+	-rm -f ./$(DEPDIR)/gexch.Plo
-+	-rm -f ./$(DEPDIR)/glfree.Plo
-+	-rm -f ./$(DEPDIR)/gload.Plo
-+	-rm -f ./$(DEPDIR)/gstore.Plo
-+	-rm -f ./$(DEPDIR)/init.Plo
-+	-rm -f ./$(DEPDIR)/lock.Plo
- 	-rm -f Makefile
- distclean-am: clean-am distclean-compile distclean-generic \
- 	distclean-hdr distclean-libtool distclean-local distclean-tags
-@@ -839,7 +862,17 @@ installcheck-am:
- maintainer-clean: maintainer-clean-recursive
- 	-rm -f $(am__CONFIG_DISTCLEAN_FILES)
- 	-rm -rf $(top_srcdir)/autom4te.cache
--	-rm -rf ./$(DEPDIR)
-+		-rm -f ./$(DEPDIR)/atomic_16.Plo
-+	-rm -f ./$(DEPDIR)/fence.Plo
-+	-rm -f ./$(DEPDIR)/fenv.Plo
-+	-rm -f ./$(DEPDIR)/flag.Plo
-+	-rm -f ./$(DEPDIR)/gcas.Plo
-+	-rm -f ./$(DEPDIR)/gexch.Plo
-+	-rm -f ./$(DEPDIR)/glfree.Plo
-+	-rm -f ./$(DEPDIR)/gload.Plo
-+	-rm -f ./$(DEPDIR)/gstore.Plo
-+	-rm -f ./$(DEPDIR)/init.Plo
-+	-rm -f ./$(DEPDIR)/lock.Plo
- 	-rm -f Makefile
- maintainer-clean-am: distclean-am maintainer-clean-generic \
- 	maintainer-clean-local
-@@ -862,18 +895,19 @@ uninstall-am: uninstall-toolexeclibLTLIBRARIES
- .MAKE: $(am__recursive_targets) all install-am install-strip
- 
- .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am all-local \
--	am--refresh check check-am clean clean-cscope clean-generic \
--	clean-libtool clean-local clean-noinstLTLIBRARIES \
--	clean-toolexeclibLTLIBRARIES cscope cscopelist-am ctags \
--	ctags-am distclean distclean-compile distclean-generic \
--	distclean-hdr distclean-libtool distclean-local distclean-tags \
--	dvi dvi-am html html-am info info-am install install-am \
--	install-data install-data-am install-dvi install-dvi-am \
--	install-exec install-exec-am install-exec-local install-html \
--	install-html-am install-info install-info-am install-man \
--	install-pdf install-pdf-am install-ps install-ps-am \
--	install-strip install-toolexeclibLTLIBRARIES installcheck \
--	installcheck-am installdirs installdirs-am maintainer-clean \
-+	am--depfiles am--refresh check check-am clean clean-cscope \
-+	clean-generic clean-libtool clean-local \
-+	clean-noinstLTLIBRARIES clean-toolexeclibLTLIBRARIES cscope \
-+	cscopelist-am ctags ctags-am distclean distclean-compile \
-+	distclean-generic distclean-hdr distclean-libtool \
-+	distclean-local distclean-tags dvi dvi-am html html-am info \
-+	info-am install install-am install-data install-data-am \
-+	install-dvi install-dvi-am install-exec install-exec-am \
-+	install-exec-local install-html install-html-am install-info \
-+	install-info-am install-man install-pdf install-pdf-am \
-+	install-ps install-ps-am install-strip \
-+	install-toolexeclibLTLIBRARIES installcheck installcheck-am \
-+	installdirs installdirs-am maintainer-clean \
- 	maintainer-clean-generic maintainer-clean-local mostlyclean \
- 	mostlyclean-compile mostlyclean-generic mostlyclean-libtool \
- 	mostlyclean-local pdf pdf-am ps ps-am tags tags-am uninstall \
-@@ -901,6 +935,9 @@ vpath % $(strip $(search_path))
- # makefile fragments to avoid broken *.Ppo getting included into the Makefile
- # when it is reloaded during the build of all-multi.
- all-multi: $(libatomic_la_LIBADD)
-+all: all-multi libatomic.la
-+	$(INSTALL_DATA) .libs/libatomic.a $(gcc_objdir)/
-+	chmod 644 $(gcc_objdir)/libatomic.a
- 
- # target overrides
- -include $(tmake_file)
-diff --git a/libatomic/aclocal.m4 b/libatomic/aclocal.m4
-index 80e24219d7d1..4bef515c0f27 100644
---- a/libatomic/aclocal.m4
-+++ b/libatomic/aclocal.m4
-@@ -1,6 +1,6 @@
--# generated automatically by aclocal 1.15.1 -*- Autoconf -*-
-+# generated automatically by aclocal 1.16.1 -*- Autoconf -*-
- 
--# Copyright (C) 1996-2017 Free Software Foundation, Inc.
-+# Copyright (C) 1996-2018 Free Software Foundation, Inc.
- 
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -20,7 +20,7 @@ You have another version of autoconf.  It may work, but is not guaranteed to.
- If you have problems, you may need to regenerate the build system entirely.
- To do so, use the procedure documented by the package, typically 'autoreconf'.])])
- 
--# Copyright (C) 2002-2017 Free Software Foundation, Inc.
-+# Copyright (C) 2002-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -32,10 +32,10 @@ To do so, use the procedure documented by the package, typically 'autoreconf'.])
- # generated from the m4 files accompanying Automake X.Y.
- # (This private macro should not be called outside this file.)
- AC_DEFUN([AM_AUTOMAKE_VERSION],
--[am__api_version='1.15'
-+[am__api_version='1.16'
- dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to
- dnl require some minimum version.  Point them to the right macro.
--m4_if([$1], [1.15.1], [],
-+m4_if([$1], [1.16.1], [],
-       [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl
- ])
- 
-@@ -51,14 +51,14 @@ m4_define([_AM_AUTOCONF_VERSION], [])
- # Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced.
- # This function is AC_REQUIREd by AM_INIT_AUTOMAKE.
- AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION],
--[AM_AUTOMAKE_VERSION([1.15.1])dnl
-+[AM_AUTOMAKE_VERSION([1.16.1])dnl
- m4_ifndef([AC_AUTOCONF_VERSION],
-   [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
- _AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))])
- 
- # Figure out how to run the assembler.                      -*- Autoconf -*-
- 
--# Copyright (C) 2001-2017 Free Software Foundation, Inc.
-+# Copyright (C) 2001-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -78,7 +78,7 @@ _AM_IF_OPTION([no-dependencies],, [_AM_DEPENDENCIES([CCAS])])dnl
- 
- # AM_AUX_DIR_EXPAND                                         -*- Autoconf -*-
- 
--# Copyright (C) 2001-2017 Free Software Foundation, Inc.
-+# Copyright (C) 2001-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -130,7 +130,7 @@ am_aux_dir=`cd "$ac_aux_dir" && pwd`
- 
- # AM_CONDITIONAL                                            -*- Autoconf -*-
- 
--# Copyright (C) 1997-2017 Free Software Foundation, Inc.
-+# Copyright (C) 1997-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -161,7 +161,7 @@ AC_CONFIG_COMMANDS_PRE(
- Usually this means the macro was only invoked conditionally.]])
- fi])])
- 
--# Copyright (C) 1999-2017 Free Software Foundation, Inc.
-+# Copyright (C) 1999-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -352,13 +352,12 @@ _AM_SUBST_NOTMAKE([am__nodep])dnl
- 
- # Generate code to set up dependency tracking.              -*- Autoconf -*-
- 
--# Copyright (C) 1999-2017 Free Software Foundation, Inc.
-+# Copyright (C) 1999-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
- # with or without modifications, as long as this notice is preserved.
- 
--
- # _AM_OUTPUT_DEPENDENCY_COMMANDS
- # ------------------------------
- AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
-@@ -366,49 +365,41 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
-   # Older Autoconf quotes --file arguments for eval, but not when files
-   # are listed without --file.  Let's play safe and only enable the eval
-   # if we detect the quoting.
--  case $CONFIG_FILES in
--  *\'*) eval set x "$CONFIG_FILES" ;;
--  *)   set x $CONFIG_FILES ;;
--  esac
-+  # TODO: see whether this extra hack can be removed once we start
-+  # requiring Autoconf 2.70 or later.
-+  AS_CASE([$CONFIG_FILES],
-+          [*\'*], [eval set x "$CONFIG_FILES"],
-+          [*], [set x $CONFIG_FILES])
-   shift
--  for mf
-+  # Used to flag and report bootstrapping failures.
-+  am_rc=0
-+  for am_mf
-   do
-     # Strip MF so we end up with the name of the file.
--    mf=`echo "$mf" | sed -e 's/:.*$//'`
--    # Check whether this is an Automake generated Makefile or not.
--    # We used to match only the files named 'Makefile.in', but
--    # some people rename them; so instead we look at the file content.
--    # Grep'ing the first line is not enough: some people post-process
--    # each Makefile.in and add a new line on top of each file to say so.
--    # Grep'ing the whole file is not good either: AIX grep has a line
-+    am_mf=`AS_ECHO(["$am_mf"]) | sed -e 's/:.*$//'`
-+    # Check whether this is an Automake generated Makefile which includes
-+    # dependency-tracking related rules and includes.
-+    # Grep'ing the whole file directly is not great: AIX grep has a line
-     # limit of 2048, but all sed's we know have understand at least 4000.
--    if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
--      dirpart=`AS_DIRNAME("$mf")`
--    else
--      continue
--    fi
--    # Extract the definition of DEPDIR, am__include, and am__quote
--    # from the Makefile without running 'make'.
--    DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
--    test -z "$DEPDIR" && continue
--    am__include=`sed -n 's/^am__include = //p' < "$mf"`
--    test -z "$am__include" && continue
--    am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
--    # Find all dependency output files, they are included files with
--    # $(DEPDIR) in their names.  We invoke sed twice because it is the
--    # simplest approach to changing $(DEPDIR) to its actual value in the
--    # expansion.
--    for file in `sed -n "
--      s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
--	 sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
--      # Make sure the directory exists.
--      test -f "$dirpart/$file" && continue
--      fdir=`AS_DIRNAME(["$file"])`
--      AS_MKDIR_P([$dirpart/$fdir])
--      # echo "creating $dirpart/$file"
--      echo '# dummy' > "$dirpart/$file"
--    done
-+    sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
-+      || continue
-+    am_dirpart=`AS_DIRNAME(["$am_mf"])`
-+    am_filepart=`AS_BASENAME(["$am_mf"])`
-+    AM_RUN_LOG([cd "$am_dirpart" \
-+      && sed -e '/# am--include-marker/d' "$am_filepart" \
-+        | $MAKE -f - am--depfiles]) || am_rc=$?
-   done
-+  if test $am_rc -ne 0; then
-+    AC_MSG_FAILURE([Something went wrong bootstrapping makefile fragments
-+    for automatic dependency tracking.  Try re-running configure with the
-+    '--disable-dependency-tracking' option to at least be able to build
-+    the package (albeit without support for automatic dependency tracking).])
-+  fi
-+  AS_UNSET([am_dirpart])
-+  AS_UNSET([am_filepart])
-+  AS_UNSET([am_mf])
-+  AS_UNSET([am_rc])
-+  rm -f conftest-deps.mk
- }
- ])# _AM_OUTPUT_DEPENDENCY_COMMANDS
- 
-@@ -417,18 +408,17 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
- # -----------------------------
- # This macro should only be invoked once -- use via AC_REQUIRE.
- #
--# This code is only required when automatic dependency tracking
--# is enabled.  FIXME.  This creates each '.P' file that we will
--# need in order to bootstrap the dependency handling code.
-+# This code is only required when automatic dependency tracking is enabled.
-+# This creates each '.Po' and '.Plo' makefile fragment that we'll need in
-+# order to bootstrap the dependency handling code.
- AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],
- [AC_CONFIG_COMMANDS([depfiles],
-      [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS],
--     [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"])
--])
-+     [AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"])])
- 
- # Do all the work for Automake.                             -*- Autoconf -*-
- 
--# Copyright (C) 1996-2017 Free Software Foundation, Inc.
-+# Copyright (C) 1996-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -515,8 +505,8 @@ AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl
- AC_REQUIRE([AC_PROG_MKDIR_P])dnl
- # For better backward compatibility.  To be removed once Automake 1.9.x
- # dies out for good.  For more background, see:
--# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
--# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
-+# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
-+# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
- AC_SUBST([mkdir_p], ['$(MKDIR_P)'])
- # We need awk for the "check" target (and possibly the TAP driver).  The
- # system "awk" is bad on some platforms.
-@@ -583,7 +573,7 @@ END
- Aborting the configuration process, to ensure you take notice of the issue.
- 
- You can download and install GNU coreutils to get an 'rm' implementation
--that behaves properly: <http://www.gnu.org/software/coreutils/>.
-+that behaves properly: <https://www.gnu.org/software/coreutils/>.
- 
- If you want to complete the configuration process using your problematic
- 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
-@@ -625,7 +615,7 @@ for _am_header in $config_headers :; do
- done
- echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count])
- 
--# Copyright (C) 2001-2017 Free Software Foundation, Inc.
-+# Copyright (C) 2001-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -649,7 +639,7 @@ AC_SUBST([install_sh])])
- # Add --enable-maintainer-mode option to configure.         -*- Autoconf -*-
- # From Jim Meyering
- 
--# Copyright (C) 1996-2017 Free Software Foundation, Inc.
-+# Copyright (C) 1996-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -684,7 +674,7 @@ AC_MSG_CHECKING([whether to enable maintainer-specific portions of Makefiles])
- 
- # Check to see how 'make' treats includes.	            -*- Autoconf -*-
- 
--# Copyright (C) 2001-2017 Free Software Foundation, Inc.
-+# Copyright (C) 2001-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -692,49 +682,42 @@ AC_MSG_CHECKING([whether to enable maintainer-specific portions of Makefiles])
- 
- # AM_MAKE_INCLUDE()
- # -----------------
--# Check to see how make treats includes.
-+# Check whether make has an 'include' directive that can support all
-+# the idioms we need for our automatic dependency tracking code.
- AC_DEFUN([AM_MAKE_INCLUDE],
--[am_make=${MAKE-make}
--cat > confinc << 'END'
-+[AC_MSG_CHECKING([whether ${MAKE-make} supports the include directive])
-+cat > confinc.mk << 'END'
- am__doit:
--	@echo this is the am__doit target
-+	@echo this is the am__doit target >confinc.out
- .PHONY: am__doit
- END
--# If we don't find an include directive, just comment out the code.
--AC_MSG_CHECKING([for style of include used by $am_make])
- am__include="#"
- am__quote=
--_am_result=none
--# First try GNU make style include.
--echo "include confinc" > confmf
--# Ignore all kinds of additional output from 'make'.
--case `$am_make -s -f confmf 2> /dev/null` in #(
--*the\ am__doit\ target*)
--  am__include=include
--  am__quote=
--  _am_result=GNU
--  ;;
--esac
--# Now try BSD make style include.
--if test "$am__include" = "#"; then
--   echo '.include "confinc"' > confmf
--   case `$am_make -s -f confmf 2> /dev/null` in #(
--   *the\ am__doit\ target*)
--     am__include=.include
--     am__quote="\""
--     _am_result=BSD
--     ;;
--   esac
--fi
--AC_SUBST([am__include])
--AC_SUBST([am__quote])
--AC_MSG_RESULT([$_am_result])
--rm -f confinc confmf
--])
-+# BSD make does it like this.
-+echo '.include "confinc.mk" # ignored' > confmf.BSD
-+# Other make implementations (GNU, Solaris 10, AIX) do it like this.
-+echo 'include confinc.mk # ignored' > confmf.GNU
-+_am_result=no
-+for s in GNU BSD; do
-+  AM_RUN_LOG([${MAKE-make} -f confmf.$s && cat confinc.out])
-+  AS_CASE([$?:`cat confinc.out 2>/dev/null`],
-+      ['0:this is the am__doit target'],
-+      [AS_CASE([$s],
-+          [BSD], [am__include='.include' am__quote='"'],
-+          [am__include='include' am__quote=''])])
-+  if test "$am__include" != "#"; then
-+    _am_result="yes ($s style)"
-+    break
-+  fi
-+done
-+rm -f confinc.* confmf.*
-+AC_MSG_RESULT([${_am_result}])
-+AC_SUBST([am__include])])
-+AC_SUBST([am__quote])])
- 
- # Fake the existence of programs that GNU maintainers use.  -*- Autoconf -*-
- 
--# Copyright (C) 1997-2017 Free Software Foundation, Inc.
-+# Copyright (C) 1997-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -773,7 +756,7 @@ fi
- 
- # Helper functions for option handling.                     -*- Autoconf -*-
- 
--# Copyright (C) 2001-2017 Free Software Foundation, Inc.
-+# Copyright (C) 2001-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -802,7 +785,7 @@ AC_DEFUN([_AM_SET_OPTIONS],
- AC_DEFUN([_AM_IF_OPTION],
- [m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])])
- 
--# Copyright (C) 1999-2017 Free Software Foundation, Inc.
-+# Copyright (C) 1999-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -849,7 +832,7 @@ AC_LANG_POP([C])])
- # For backward compatibility.
- AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])])
- 
--# Copyright (C) 2001-2017 Free Software Foundation, Inc.
-+# Copyright (C) 2001-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -868,7 +851,7 @@ AC_DEFUN([AM_RUN_LOG],
- 
- # Check to make sure that the build environment is sane.    -*- Autoconf -*-
- 
--# Copyright (C) 1996-2017 Free Software Foundation, Inc.
-+# Copyright (C) 1996-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -949,7 +932,7 @@ AC_CONFIG_COMMANDS_PRE(
- rm -f conftest.file
- ])
- 
--# Copyright (C) 2009-2017 Free Software Foundation, Inc.
-+# Copyright (C) 2009-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -1009,7 +992,7 @@ AC_SUBST([AM_BACKSLASH])dnl
- _AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl
- ])
- 
--# Copyright (C) 2001-2017 Free Software Foundation, Inc.
-+# Copyright (C) 2001-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -1037,7 +1020,7 @@ fi
- INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s"
- AC_SUBST([INSTALL_STRIP_PROGRAM])])
- 
--# Copyright (C) 2006-2017 Free Software Foundation, Inc.
-+# Copyright (C) 2006-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -1056,7 +1039,7 @@ AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)])
- 
- # Check how to create a tarball.                            -*- Autoconf -*-
- 
--# Copyright (C) 2004-2017 Free Software Foundation, Inc.
-+# Copyright (C) 2004-2018 Free Software Foundation, Inc.
- #
- # This file is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-diff --git a/libatomic/configure b/libatomic/configure
-index d579bab96f86..d14a412ae164 100755
---- a/libatomic/configure
-+++ b/libatomic/configure
-@@ -698,7 +698,6 @@ am__nodep
- AMDEPBACKSLASH
- AMDEP_FALSE
- AMDEP_TRUE
--am__quote
- am__include
- DEPDIR
- OBJEXT
-@@ -706,8 +705,8 @@ EXEEXT
- ac_ct_CC
- CPPFLAGS
- LDFLAGS
--CFLAGS
- CC
-+CFLAGS
- toolexeclibdir
- toolexecdir
- multi_basedir
-@@ -771,6 +770,7 @@ infodir
- docdir
- oldincludedir
- includedir
-+runstatedir
- localstatedir
- sharedstatedir
- sysconfdir
-@@ -789,7 +789,8 @@ PACKAGE_VERSION
- PACKAGE_TARNAME
- PACKAGE_NAME
- PATH_SEPARATOR
--SHELL'
-+SHELL
-+am__quote'
- ac_subst_files=''
- ac_user_opts='
- enable_option_checking
-@@ -855,6 +856,7 @@ datadir='${datarootdir}'
- sysconfdir='${prefix}/etc'
- sharedstatedir='${prefix}/com'
- localstatedir='${prefix}/var'
-+runstatedir='${localstatedir}/run'
- includedir='${prefix}/include'
- oldincludedir='/usr/include'
- docdir='${datarootdir}/doc/${PACKAGE_TARNAME}'
-@@ -1107,6 +1109,15 @@ do
-   | -silent | --silent | --silen | --sile | --sil)
-     silent=yes ;;
- 
-+  -runstatedir | --runstatedir | --runstatedi | --runstated \
-+  | --runstate | --runstat | --runsta | --runst | --runs \
-+  | --run | --ru | --r)
-+    ac_prev=runstatedir ;;
-+  -runstatedir=* | --runstatedir=* | --runstatedi=* | --runstated=* \
-+  | --runstate=* | --runstat=* | --runsta=* | --runst=* | --runs=* \
-+  | --run=* | --ru=* | --r=*)
-+    runstatedir=$ac_optarg ;;
-+
-   -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb)
-     ac_prev=sbindir ;;
-   -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \
-@@ -1244,7 +1255,7 @@ fi
- for ac_var in	exec_prefix prefix bindir sbindir libexecdir datarootdir \
- 		datadir sysconfdir sharedstatedir localstatedir includedir \
- 		oldincludedir docdir infodir htmldir dvidir pdfdir psdir \
--		libdir localedir mandir
-+		libdir localedir mandir runstatedir
- do
-   eval ac_val=\$$ac_var
-   # Remove trailing slashes.
-@@ -1397,6 +1408,7 @@ Fine tuning of the installation directories:
-   --sysconfdir=DIR        read-only single-machine data [PREFIX/etc]
-   --sharedstatedir=DIR    modifiable architecture-independent data [PREFIX/com]
-   --localstatedir=DIR     modifiable single-machine data [PREFIX/var]
-+  --runstatedir=DIR       modifiable per-process data [LOCALSTATEDIR/run]
-   --libdir=DIR            object code libraries [EPREFIX/lib]
-   --includedir=DIR        C header files [PREFIX/include]
-   --oldincludedir=DIR     C header files for non-gcc [/usr/include]
-@@ -2739,7 +2751,7 @@ target_alias=${target_alias-$host_alias}
- #  -Wall:  turns on all automake warnings...
- #  -Wno-portability:  ...except this one, since GNU make is required.
- #  -Wno-override: ... and this one, since we do want this in testsuite.
--am__api_version='1.15'
-+am__api_version='1.16'
- 
- # Find a good install program.  We prefer a C program (faster),
- # so one script is as good as another.  But avoid the broken or
-@@ -3255,8 +3267,8 @@ MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"}
- 
- # For better backward compatibility.  To be removed once Automake 1.9.x
- # dies out for good.  For more background, see:
--# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
--# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
-+# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
-+# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
- mkdir_p='$(MKDIR_P)'
- 
- # We need awk for the "check" target (and possibly the TAP driver).  The
-@@ -3307,7 +3319,7 @@ END
- Aborting the configuration process, to ensure you take notice of the issue.
- 
- You can download and install GNU coreutils to get an 'rm' implementation
--that behaves properly: <http://www.gnu.org/software/coreutils/>.
-+that behaves properly: <https://www.gnu.org/software/coreutils/>.
- 
- If you want to complete the configuration process using your problematic
- 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
-@@ -3409,6 +3421,8 @@ esac
- 
- 
- 
-+CFLAGS="$CFLAGS -fno-link-libatomic"
-+
- # Check the compiler.
- # The same as in boehm-gc and libstdc++. Have to borrow it from there.
- # We must force CC to /not/ be precious variables; otherwise
-@@ -4268,45 +4282,45 @@ DEPDIR="${am__leading_dot}deps"
- 
- ac_config_commands="$ac_config_commands depfiles"
- 
--
--am_make=${MAKE-make}
--cat > confinc << 'END'
-+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} supports the include directive" >&5
-+$as_echo_n "checking whether ${MAKE-make} supports the include directive... " >&6; }
-+cat > confinc.mk << 'END'
- am__doit:
--	@echo this is the am__doit target
-+	@echo this is the am__doit target >confinc.out
- .PHONY: am__doit
- END
--# If we don't find an include directive, just comment out the code.
--{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5
--$as_echo_n "checking for style of include used by $am_make... " >&6; }
- am__include="#"
- am__quote=
--_am_result=none
--# First try GNU make style include.
--echo "include confinc" > confmf
--# Ignore all kinds of additional output from 'make'.
--case `$am_make -s -f confmf 2> /dev/null` in #(
--*the\ am__doit\ target*)
--  am__include=include
--  am__quote=
--  _am_result=GNU
--  ;;
--esac
--# Now try BSD make style include.
--if test "$am__include" = "#"; then
--   echo '.include "confinc"' > confmf
--   case `$am_make -s -f confmf 2> /dev/null` in #(
--   *the\ am__doit\ target*)
--     am__include=.include
--     am__quote="\""
--     _am_result=BSD
-+# BSD make does it like this.
-+echo '.include "confinc.mk" # ignored' > confmf.BSD
-+# Other make implementations (GNU, Solaris 10, AIX) do it like this.
-+echo 'include confinc.mk # ignored' > confmf.GNU
-+_am_result=no
-+for s in GNU BSD; do
-+  { echo "$as_me:$LINENO: ${MAKE-make} -f confmf.$s && cat confinc.out" >&5
-+   (${MAKE-make} -f confmf.$s && cat confinc.out) >&5 2>&5
-+   ac_status=$?
-+   echo "$as_me:$LINENO: \$? = $ac_status" >&5
-+   (exit $ac_status); }
-+  case $?:`cat confinc.out 2>/dev/null` in #(
-+  '0:this is the am__doit target') :
-+    case $s in #(
-+  BSD) :
-+    am__include='.include' am__quote='"' ;; #(
-+  *) :
-+    am__include='include' am__quote='' ;;
-+esac ;; #(
-+  *) :
-      ;;
--   esac
--fi
--
--
--{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5
--$as_echo "$_am_result" >&6; }
--rm -f confinc confmf
-+esac
-+  if test "$am__include" != "#"; then
-+    _am_result="yes ($s style)"
-+    break
-+  fi
-+done
-+rm -f confinc.* confmf.*
-+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: ${_am_result}" >&5
-+$as_echo "${_am_result}" >&6; }
- 
- # Check whether --enable-dependency-tracking was given.
- if test "${enable_dependency_tracking+set}" = set; then :
-@@ -4591,8 +4605,6 @@ fi
- 
- 
- 
--
--
- # In order to override CFLAGS_FOR_TARGET, all of our special flags go
- # in XCFLAGS.  But we need them in CFLAGS during configury.  So put them
- # in both places for now and restore CFLAGS at the end of config.
-@@ -11456,7 +11468,7 @@ else
-   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
-   lt_status=$lt_dlunknown
-   cat > conftest.$ac_ext <<_LT_EOF
--#line 11459 "configure"
-+#line 11471 "configure"
- #include "confdefs.h"
- 
- #if HAVE_DLFCN_H
-@@ -11562,7 +11574,7 @@ else
-   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
-   lt_status=$lt_dlunknown
-   cat > conftest.$ac_ext <<_LT_EOF
--#line 11565 "configure"
-+#line 11577 "configure"
- #include "confdefs.h"
- 
- #if HAVE_DLFCN_H
-@@ -11929,6 +11941,7 @@ ac_compiler_gnu=$ac_cv_c_compiler_gnu
-     ;;
- esac
- 
-+SYSROOT_CFLAGS_FOR_TARGET="$SYSROOT_CFLAGS_FOR_TARGET -fno-link-libatomic"
- 
- 
- # Get target configury.
-@@ -14994,6 +15007,8 @@ rm -f core conftest.err conftest.$ac_objext \
-   ;;
- esac
- 
-+CFLAGS="$CFLAGS -fno-link-libatomic"
-+
- # See what sort of export controls are available.
- 
-   { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the target supports hidden visibility" >&5
-@@ -15753,12 +15768,16 @@ fi
- 
- XCFLAGS="$XCFLAGS $CET_FLAGS"
- 
--XCFLAGS="$XCFLAGS $XPCFLAGS"
-+XCFLAGS="$XCFLAGS $XPCFLAGS -fno-link-libatomic"
-+XLDFLAGS="$XLDFLAGS -fno-link-libatomic"
-+
-+
- 
- 
- 
- 
- 
-+LDFLAGS="$LDFLAGS -fno-link-libatomic"
- 
- 
- # Conditionalize the makefile for this target machine.
-@@ -16620,7 +16639,7 @@ CC="$CC"
- CXX="$CXX"
- GFORTRAN="$GFORTRAN"
- GDC="$GDC"
--AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"
-+AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"
- 
- 
- # The HP-UX ksh and POSIX shell print the target directory to stdout
-@@ -17523,29 +17542,35 @@ esac ;;
-   # Older Autoconf quotes --file arguments for eval, but not when files
-   # are listed without --file.  Let's play safe and only enable the eval
-   # if we detect the quoting.
--  case $CONFIG_FILES in
--  *\'*) eval set x "$CONFIG_FILES" ;;
--  *)   set x $CONFIG_FILES ;;
--  esac
-+  # TODO: see whether this extra hack can be removed once we start
-+  # requiring Autoconf 2.70 or later.
-+  case $CONFIG_FILES in #(
-+  *\'*) :
-+    eval set x "$CONFIG_FILES" ;; #(
-+  *) :
-+    set x $CONFIG_FILES ;; #(
-+  *) :
-+     ;;
-+esac
-   shift
--  for mf
-+  # Used to flag and report bootstrapping failures.
-+  am_rc=0
-+  for am_mf
-   do
-     # Strip MF so we end up with the name of the file.
--    mf=`echo "$mf" | sed -e 's/:.*$//'`
--    # Check whether this is an Automake generated Makefile or not.
--    # We used to match only the files named 'Makefile.in', but
--    # some people rename them; so instead we look at the file content.
--    # Grep'ing the first line is not enough: some people post-process
--    # each Makefile.in and add a new line on top of each file to say so.
--    # Grep'ing the whole file is not good either: AIX grep has a line
-+    am_mf=`$as_echo "$am_mf" | sed -e 's/:.*$//'`
-+    # Check whether this is an Automake generated Makefile which includes
-+    # dependency-tracking related rules and includes.
-+    # Grep'ing the whole file directly is not great: AIX grep has a line
-     # limit of 2048, but all sed's we know have understand at least 4000.
--    if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
--      dirpart=`$as_dirname -- "$mf" ||
--$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
--	 X"$mf" : 'X\(//\)[^/]' \| \
--	 X"$mf" : 'X\(//\)$' \| \
--	 X"$mf" : 'X\(/\)' \| . 2>/dev/null ||
--$as_echo X"$mf" |
-+    sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
-+      || continue
-+    am_dirpart=`$as_dirname -- "$am_mf" ||
-+$as_expr X"$am_mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
-+	 X"$am_mf" : 'X\(//\)[^/]' \| \
-+	 X"$am_mf" : 'X\(//\)$' \| \
-+	 X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
-+$as_echo X"$am_mf" |
-     sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
- 	    s//\1/
- 	    q
-@@ -17563,53 +17588,48 @@ $as_echo X"$mf" |
- 	    q
- 	  }
- 	  s/.*/./; q'`
--    else
--      continue
--    fi
--    # Extract the definition of DEPDIR, am__include, and am__quote
--    # from the Makefile without running 'make'.
--    DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
--    test -z "$DEPDIR" && continue
--    am__include=`sed -n 's/^am__include = //p' < "$mf"`
--    test -z "$am__include" && continue
--    am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
--    # Find all dependency output files, they are included files with
--    # $(DEPDIR) in their names.  We invoke sed twice because it is the
--    # simplest approach to changing $(DEPDIR) to its actual value in the
--    # expansion.
--    for file in `sed -n "
--      s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
--	 sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
--      # Make sure the directory exists.
--      test -f "$dirpart/$file" && continue
--      fdir=`$as_dirname -- "$file" ||
--$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
--	 X"$file" : 'X\(//\)[^/]' \| \
--	 X"$file" : 'X\(//\)$' \| \
--	 X"$file" : 'X\(/\)' \| . 2>/dev/null ||
--$as_echo X"$file" |
--    sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
--	    s//\1/
--	    q
--	  }
--	  /^X\(\/\/\)[^/].*/{
-+    am_filepart=`$as_basename -- "$am_mf" ||
-+$as_expr X/"$am_mf" : '.*/\([^/][^/]*\)/*$' \| \
-+	 X"$am_mf" : 'X\(//\)$' \| \
-+	 X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
-+$as_echo X/"$am_mf" |
-+    sed '/^.*\/\([^/][^/]*\)\/*$/{
- 	    s//\1/
- 	    q
- 	  }
--	  /^X\(\/\/\)$/{
-+	  /^X\/\(\/\/\)$/{
- 	    s//\1/
- 	    q
- 	  }
--	  /^X\(\/\).*/{
-+	  /^X\/\(\/\).*/{
- 	    s//\1/
- 	    q
- 	  }
- 	  s/.*/./; q'`
--      as_dir=$dirpart/$fdir; as_fn_mkdir_p
--      # echo "creating $dirpart/$file"
--      echo '# dummy' > "$dirpart/$file"
--    done
-+    { echo "$as_me:$LINENO: cd "$am_dirpart" \
-+      && sed -e '/# am--include-marker/d' "$am_filepart" \
-+        | $MAKE -f - am--depfiles" >&5
-+   (cd "$am_dirpart" \
-+      && sed -e '/# am--include-marker/d' "$am_filepart" \
-+        | $MAKE -f - am--depfiles) >&5 2>&5
-+   ac_status=$?
-+   echo "$as_me:$LINENO: \$? = $ac_status" >&5
-+   (exit $ac_status); } || am_rc=$?
-   done
-+  if test $am_rc -ne 0; then
-+    { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5
-+$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
-+as_fn_error $? "Something went wrong bootstrapping makefile fragments
-+    for automatic dependency tracking.  Try re-running configure with the
-+    '--disable-dependency-tracking' option to at least be able to build
-+    the package (albeit without support for automatic dependency tracking).
-+See \`config.log' for more details" "$LINENO" 5; }
-+  fi
-+  { am_dirpart=; unset am_dirpart;}
-+  { am_filepart=; unset am_filepart;}
-+  { am_mf=; unset am_mf;}
-+  { am_rc=; unset am_rc;}
-+  rm -f conftest-deps.mk
- }
-  ;;
-     "libtool":C)
-diff --git a/libatomic/configure.ac b/libatomic/configure.ac
-index aafae71028d2..3178f2eefea2 100644
---- a/libatomic/configure.ac
-+++ b/libatomic/configure.ac
-@@ -123,6 +123,8 @@ esac
- AC_SUBST(toolexecdir)
- AC_SUBST(toolexeclibdir)
- 
-+CFLAGS="$CFLAGS -fno-link-libatomic"
-+AC_SUBST(CFLAGS)
- # Check the compiler.
- # The same as in boehm-gc and libstdc++. Have to borrow it from there.
- # We must force CC to /not/ be precious variables; otherwise
-@@ -135,8 +137,6 @@ AC_PROG_CC
- AM_PROG_AS
- m4_rename_force([real_PRECIOUS],[_AC_ARG_VAR_PRECIOUS])
- 
--AC_SUBST(CFLAGS)
--
- # In order to override CFLAGS_FOR_TARGET, all of our special flags go
- # in XCFLAGS.  But we need them in CFLAGS during configury.  So put them
- # in both places for now and restore CFLAGS at the end of config.
-@@ -172,6 +172,7 @@ case "$target" in
-     ;;
- esac
- 
-+SYSROOT_CFLAGS_FOR_TARGET="$SYSROOT_CFLAGS_FOR_TARGET -fno-link-libatomic"
- AC_SUBST(SYSROOT_CFLAGS_FOR_TARGET)
- 
- # Get target configury.
-@@ -239,6 +240,8 @@ case " $config_path " in
-   ;;
- esac
- 
-+CFLAGS="$CFLAGS -fno-link-libatomic"
-+
- # See what sort of export controls are available.
- LIBAT_CHECK_ATTRIBUTE_VISIBILITY
- LIBAT_CHECK_ATTRIBUTE_DLLEXPORT
-@@ -266,7 +269,8 @@ AS_IF([test "x$enable_werror" != "xno" && test "x$GCC" = "xyes"],
- GCC_CET_FLAGS(CET_FLAGS)
- XCFLAGS="$XCFLAGS $CET_FLAGS"
- 
--XCFLAGS="$XCFLAGS $XPCFLAGS"
-+XCFLAGS="$XCFLAGS $XPCFLAGS -fno-link-libatomic"
-+XLDFLAGS="$XLDFLAGS -fno-link-libatomic"
- 
- AC_SUBST(config_path)
- AC_SUBST(XCFLAGS)
-@@ -274,6 +278,9 @@ AC_SUBST(XLDFLAGS)
- AC_SUBST(LIBS)
- AC_SUBST(SIZES)
- 
-+LDFLAGS="$LDFLAGS -fno-link-libatomic"
-+AC_SUBST(LDFLAGS)
-+
- # Conditionalize the makefile for this target machine.
- tmake_file_=
- for f in ${tmake_file}
-diff --git a/libatomic/testsuite/Makefile.in b/libatomic/testsuite/Makefile.in
-index 247268f19490..3974ce8fe9f4 100644
---- a/libatomic/testsuite/Makefile.in
-+++ b/libatomic/testsuite/Makefile.in
-@@ -1,7 +1,7 @@
--# Makefile.in generated by automake 1.15.1 from Makefile.am.
-+# Makefile.in generated by automake 1.16.1 from Makefile.am.
- # @configure_input@
- 
--# Copyright (C) 1994-2017 Free Software Foundation, Inc.
-+# Copyright (C) 1994-2018 Free Software Foundation, Inc.
- 
- # This Makefile.in is free software; the Free Software Foundation
- # gives unlimited permission to copy and/or distribute it,
-@@ -253,6 +253,7 @@ pdfdir = @pdfdir@
- prefix = @prefix@
- program_transform_name = @program_transform_name@
- psdir = @psdir@
-+runstatedir = @runstatedir@
- sbindir = @sbindir@
- sharedstatedir = @sharedstatedir@
- srcdir = @srcdir@
-@@ -300,8 +301,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
- 	  *config.status*) \
- 	    cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
- 	  *) \
--	    echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
--	    cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
-+	    echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \
-+	    cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \
- 	esac;
- 
- $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
-@@ -332,7 +333,7 @@ check-DEJAGNU: site.exp
- 	EXPECT=$(EXPECT); export EXPECT; \
- 	if $(SHELL) -c "$(RUNTEST) --version" > /dev/null 2>&1; then \
- 	  exit_status=0; l='$(DEJATOOL)'; for tool in $$l; do \
--	    if $(RUNTEST) $(AM_RUNTESTFLAGS) $(RUNTESTDEFAULTFLAGS) $(RUNTESTFLAGS); \
-+	    if $(RUNTEST) $(RUNTESTDEFAULTFLAGS) $(AM_RUNTESTFLAGS) $(RUNTESTFLAGS); \
- 	    then :; else exit_status=1; fi; \
- 	  done; \
- 	else echo "WARNING: could not find '$(RUNTEST)'" 1>&2; :;\
-
-base-commit: 451ff5b58f7c5958f8341160343680262944a63f
-prerequisite-patch-id: cca034489e37f362f6ff4ff1aba0258270153a6a
-prerequisite-patch-id: dcb0315887787c40fae21980c53d20d0b6e234b7
--- 
-2.47.1
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-06 10:03 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-06 10:03 UTC (permalink / raw
  To: gentoo-commits
commit:     d26e153ec5586afaa1ef59cf063d761156b953fc
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  6 10:03:12 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan  6 10:03:12 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=d26e153e
15.0.0: drop 78_all_PR118032-tree-switch-conversion-don-t-apply-switch-size-limit.patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-conversion-don-t-apply-switch-size-limit.patch | 51 ----------------------
 15.0.0/gentoo/README.history                       |  1 -
 2 files changed, 52 deletions(-)
diff --git a/15.0.0/gentoo/78_all_PR118032-tree-switch-conversion-don-t-apply-switch-size-limit.patch b/15.0.0/gentoo/78_all_PR118032-tree-switch-conversion-don-t-apply-switch-size-limit.patch
deleted file mode 100644
index 20018ef..0000000
--- a/15.0.0/gentoo/78_all_PR118032-tree-switch-conversion-don-t-apply-switch-size-limit.patch
+++ /dev/null
@@ -1,51 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/20250105172539.906393-1-mark@klomp.org/
-
-From 4e8dc9973c98a8b0c5cfe555221dc7dee5d92662 Mon Sep 17 00:00:00 2001
-Message-ID: <4e8dc9973c98a8b0c5cfe555221dc7dee5d92662.1736136715.git.sam@gentoo.org>
-From: Mark Wielaard <mark@klomp.org>
-Date: Sun, 5 Jan 2025 18:25:39 +0100
-Subject: [PATCH] tree-switch-conversion: don't apply switch size limit on jump
- tables
-
-commit 56946c801a7c ("gimple: Add limit after which slower switchlower
-algs are used [PR117091] [PR117352]") introduced a limit on the number
-of cases of a switch. It also bails out on finding jump tables if the
-switch is too large. This introduces a compile time regression during
-bootstrap. A riscv bootstrap takes hours longer. Particularly
-insn-attrtab.cc will take hours instead of minutes. Fix this by not
-applying the switch size limit on jump tables.
-
-An alternative would be to implement greedy switch clustering for jump
-tables as is done for switch bitmap clustering.
-
-gcc/ChangeLog:
-
-PR tree-optimization/118032
-	* tree-switch-conversion.cc (jump_table_cluster::find_jump_tables):
-	Remove param_switch_lower_slow_alg_max_cases check.
----
- gcc/tree-switch-conversion.cc | 4 ----
- 1 file changed, 4 deletions(-)
-
-diff --git a/gcc/tree-switch-conversion.cc b/gcc/tree-switch-conversion.cc
-index 432970597c97..39a8a893edde 100644
---- a/gcc/tree-switch-conversion.cc
-+++ b/gcc/tree-switch-conversion.cc
-@@ -1643,10 +1643,6 @@ jump_table_cluster::find_jump_tables (vec<cluster *> &clusters)
- 
-   unsigned l = clusters.length ();
- 
--  /* Note: l + 1 is the number of cases of the switch.  */
--  if (l + 1 > (unsigned) param_switch_lower_slow_alg_max_cases)
--    return clusters.copy ();
--
-   auto_vec<min_cluster_item> min;
-   min.reserve (l + 1);
- 
-
-base-commit: 451ff5b58f7c5958f8341160343680262944a63f
-prerequisite-patch-id: cca034489e37f362f6ff4ff1aba0258270153a6a
-prerequisite-patch-id: dcb0315887787c40fae21980c53d20d0b6e234b7
--- 
-2.47.1
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index edfaab4..666e4b2 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,7 +1,6 @@
 37	????
 
 	- 78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch
-	+ 78_all_PR118032-tree-switch-conversion-don-t-apply-switch-size-limit.patch
 	+ 81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
 
 36	5 January 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-06 10:50 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-06 10:50 UTC (permalink / raw
  To: gentoo-commits
commit:     f6d3d0becd191f48aca221595377e39e53708adf
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  6 10:46:20 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan  6 10:50:06 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=f6d3d0be
15.0.0: bring back atomic patch
I PEBKAC'd and used the wrong version of the patch before.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...358-Enable-automatic-linking-of-libatomic.patch | 536 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 537 insertions(+)
diff --git a/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch b/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
new file mode 100644
index 0000000..d3424e7
--- /dev/null
+++ b/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
@@ -0,0 +1,536 @@
+https://inbox.sourceware.org/gcc-patches/IA1PR12MB90310A559B28E87BF456C942CE072@IA1PR12MB9031.namprd12.prod.outlook.com/#t
+
+PR81358: Enable automatic linking of libatomic.
+
+ChangeLog:
+	PR driver/81358
+	* Makefile.def: Add dependencies so libatomic is built before target
+	libraries are configured.
+	* Makefile.tpl: Export TARGET_CONFIGDIRS.
+	* configure.ac: Add libatomic to bootstrap_target_libs.
+	* Makefile.in: Regenerate.
+	* configure: Regenerate.
+
+gcc/ChangeLog:
+	PR driver/81358
+	* common.opt: New option -flink-libatomic.
+	* gcc.cc (LINK_LIBATOMIC_SPEC): New macro.
+	* config/gnu-user.h (GNU_USER_TARGET_LINK_GCC_C_SEQUENCE_SPEC): Use
+	LINK_LIBATOMIC_SPEC.
+	* doc/invoke.texi: Document -flink-libatomic.
+	* configure.ac: Define TARGET_PROVIDES_LIBATOMIC.
+	* configure: Regenerate.
+	* config.in: Regenerate.
+
+libatomic/ChangeLog:
+	PR driver/81358
+	* Makefile.am: Pass -fno-link-libatomic.
+	New rule all.
+	* configure.ac: Assert that CFLAGS is set and pass -fno-link-libatomic. 
+	* Makefile.in: Regenerate.
+	* configure: Regenerate.
+
+Signed-off-by: Prathamesh Kulkarni <prathameshk@nvidia.com>
+Co-authored-by: Matthew Malcolmson <mmalcolmson@nvidia.com>
+
+diff --git a/Makefile.def b/Makefile.def
+index 19954e7d731..90899fa28cf 100644
+--- a/Makefile.def
++++ b/Makefile.def
+@@ -656,6 +656,26 @@ lang_env_dependencies = { module=libgcc; no_gcc=true; no_c=true; };
+ // a dependency on libgcc for native targets to configure.
+ lang_env_dependencies = { module=libiberty; no_c=true; };
+ 
++dependencies = { module=configure-target-libbacktrace; on=all-target-libatomic; };
++dependencies = { module=configure-target-libgloss; on=all-target-libatomic; };
++dependencies = { module=configure-target-newlib; on=all-target-libatomic; };
++dependencies = { module=configure-target-libgomp; on=all-target-libatomic; };
++dependencies = { module=configure-target-libitm; on=all-target-libatomic; };
++dependencies = { module=configure-target-libstdc++v3; on=all-target-libatomic; };
++dependencies = { module=configure-target-libsanitizer; on=all-target-libatomic; };
++dependencies = { module=configure-target-libvtv; on=all-target-libatomic; };
++dependencies = { module=configure-target-libssp; on=all-target-libatomic; };
++dependencies = { module=configure-target-libquadmath; on=all-target-libatomic; };
++dependencies = { module=configure-target-libgfortran; on=all-target-libatomic; };
++dependencies = { module=configure-target-libffi; on=all-target-libatomic; };
++dependencies = { module=configure-target-libobjc; on=all-target-libatomic; };
++dependencies = { module=configure-target-libada; on=all-target-libatomic; };
++dependencies = { module=configure-target-libgm2; on=all-target-libatomic; };
++dependencies = { module=configure-target-libgo; on=all-target-libatomic; };
++dependencies = { module=configure-target-libgrust; on=all-target-libatomic; };
++dependencies = { module=configure-target-libphobos; on=all-target-libatomic; };
++dependencies = { module=configure-target-zlib; on=all-target-libatomic; };
++
+ dependencies = { module=configure-target-fastjar; on=configure-target-zlib; };
+ dependencies = { module=all-target-fastjar; on=all-target-zlib; };
+ dependencies = { module=configure-target-libgo; on=configure-target-libffi; };
+diff --git a/Makefile.in b/Makefile.in
+index 966d6045496..4a85f11d7e6 100644
+--- a/Makefile.in
++++ b/Makefile.in
+@@ -242,6 +242,7 @@ HOST_EXPORTS = \
+ 	GMPINC="$(HOST_GMPINC)"; export GMPINC; \
+ 	ISLLIBS="$(HOST_ISLLIBS)"; export ISLLIBS; \
+ 	ISLINC="$(HOST_ISLINC)"; export ISLINC; \
++	TARGET_CONFIGDIRS="$(TARGET_CONFIGDIRS)"; export TARGET_CONFIGDIRS; \
+ 	XGCC_FLAGS_FOR_TARGET="$(XGCC_FLAGS_FOR_TARGET)"; export XGCC_FLAGS_FOR_TARGET; \
+ @if gcc-bootstrap
+ 	$(RPATH_ENVVAR)=`echo "$(TARGET_LIB_PATH)$$$(RPATH_ENVVAR)" | sed 's,::*,:,g;s,^:*,,;s,:*$$,,'`; export $(RPATH_ENVVAR); \
+@@ -68551,6 +68552,66 @@ all-flex: maybe-all-build-bison
+ all-flex: maybe-all-m4
+ all-flex: maybe-all-build-texinfo
+ all-m4: maybe-all-build-texinfo
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
+ configure-target-libgo: maybe-configure-target-libffi
+ all-target-libgo: maybe-all-target-libffi
+ configure-target-libphobos: maybe-configure-target-libbacktrace
+@@ -68678,6 +68739,45 @@ configure-m4: stage_last
+ @endif gcc-bootstrap
+ 
+ @if gcc-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libgloss: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-newlib: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libitm: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libstdc++v3: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libssp: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libquadmath: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libgfortran: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libffi: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libobjc: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libada: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libgm2: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libgo: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
++@unless target-libatomic-bootstrap
++configure-target-libgrust: maybe-all-target-libatomic
++@endunless target-libatomic-bootstrap
+ @unless target-zlib-bootstrap
+ configure-target-fastjar: maybe-configure-target-zlib
+ @endunless target-zlib-bootstrap
+@@ -68755,6 +68855,19 @@ all-fastjar: maybe-all-libiberty
+ all-bison: maybe-all-gettext
+ all-flex: maybe-all-gettext
+ all-m4: maybe-all-gettext
++configure-target-libgloss: maybe-all-target-libatomic
++configure-target-newlib: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libstdc++v3: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
+ configure-target-fastjar: maybe-configure-target-zlib
+ all-target-fastjar: maybe-all-target-zlib
+ configure-target-libgo: maybe-all-target-libstdc++-v3
+diff --git a/Makefile.tpl b/Makefile.tpl
+index da38dca697a..c6b2f7504ad 100644
+--- a/Makefile.tpl
++++ b/Makefile.tpl
+@@ -245,6 +245,7 @@ HOST_EXPORTS = \
+ 	GMPINC="$(HOST_GMPINC)"; export GMPINC; \
+ 	ISLLIBS="$(HOST_ISLLIBS)"; export ISLLIBS; \
+ 	ISLINC="$(HOST_ISLINC)"; export ISLINC; \
++	TARGET_CONFIGDIRS="$(TARGET_CONFIGDIRS)"; export TARGET_CONFIGDIRS; \
+ 	XGCC_FLAGS_FOR_TARGET="$(XGCC_FLAGS_FOR_TARGET)"; export XGCC_FLAGS_FOR_TARGET; \
+ @if gcc-bootstrap
+ 	$(RPATH_ENVVAR)=`echo "$(TARGET_LIB_PATH)$$$(RPATH_ENVVAR)" | sed 's,::*,:,g;s,^:*,,;s,:*$$,,'`; export $(RPATH_ENVVAR); \
+diff --git a/configure b/configure
+index 4ae8e1242af..532e4527719 100755
+--- a/configure
++++ b/configure
+@@ -10924,6 +10924,11 @@ if echo " ${target_configdirs} " | grep " libgomp " > /dev/null 2>&1 ; then
+   bootstrap_target_libs=${bootstrap_target_libs}target-libgomp,
+ fi
+ 
++# If we are building libatomic, bootstrap it.
++if echo " ${target_configdirs} " | grep " libatomic " > /dev/null 2>&1 ; then
++  bootstrap_target_libs=${bootstrap_target_libs}target-libatomic,
++fi
++
+ # If we are building libsanitizer and $BUILD_CONFIG contains bootstrap-asan
+ # or bootstrap-ubsan, bootstrap it.
+ if echo " ${target_configdirs} " | grep " libsanitizer " > /dev/null 2>&1; then
+diff --git a/configure.ac b/configure.ac
+index 9a72b2311bd..c44d84f32ce 100644
+--- a/configure.ac
++++ b/configure.ac
+@@ -3151,6 +3151,11 @@ if echo " ${target_configdirs} " | grep " libgomp " > /dev/null 2>&1 ; then
+   bootstrap_target_libs=${bootstrap_target_libs}target-libgomp,
+ fi
+ 
++# If we are building libatomic, bootstrap it.
++if echo " ${target_configdirs} " | grep " libatomic " > /dev/null 2>&1 ; then
++  bootstrap_target_libs=${bootstrap_target_libs}target-libatomic,
++fi
++
+ # If we are building libsanitizer and $BUILD_CONFIG contains bootstrap-asan
+ # or bootstrap-ubsan, bootstrap it.
+ if echo " ${target_configdirs} " | grep " libsanitizer " > /dev/null 2>&1; then
+diff --git a/gcc/common.opt b/gcc/common.opt
+index 1b72826d44b..30530cc8b71 100644
+--- a/gcc/common.opt
++++ b/gcc/common.opt
+@@ -3361,6 +3361,9 @@ Use the Modern linker (MOLD) linker instead of the default linker.
+ fuse-linker-plugin
+ Common Undocumented Var(flag_use_linker_plugin)
+ 
++flink-libatomic
++Common Driver Var(flag_link_libatomic) Init(1)
++
+ ; Positive if we should track variables, negative if we should run
+ ; the var-tracking pass only to discard debug annotations, zero if
+ ; we're not to run it.
+diff --git a/gcc/config.in b/gcc/config.in
+index d8145a1453b..b5060d2c0c8 100644
+--- a/gcc/config.in
++++ b/gcc/config.in
+@@ -2558,6 +2558,12 @@
+ #endif
+ 
+ 
++/* Define if libatomic is built for the target */
++#ifndef USED_FOR_TARGET
++#undef TARGET_PROVIDES_LIBATOMIC
++#endif
++
++
+ /* Define to 1 if you can safely include both <sys/time.h> and <time.h>. */
+ #ifndef USED_FOR_TARGET
+ #undef TIME_WITH_SYS_TIME
+diff --git a/gcc/config/gnu-user.h b/gcc/config/gnu-user.h
+index f7eefdafe8b..27d0ef07e1e 100644
+--- a/gcc/config/gnu-user.h
++++ b/gcc/config/gnu-user.h
+@@ -109,8 +109,9 @@ see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
+ #define LINK_EH_SPEC "%{!static|static-pie:--eh-frame-hdr} "
+ #endif
+ 
++
+ #define GNU_USER_TARGET_LINK_GCC_C_SEQUENCE_SPEC \
+-  "%{static|static-pie:--start-group} %G %{!nolibc:%L} \
++  "%{static|static-pie:--start-group} %G %{!nolibc:" LINK_LIBATOMIC_SPEC "%L} \
+    %{static|static-pie:--end-group}%{!static:%{!static-pie:%G}}"
+ 
+ #undef LINK_GCC_C_SEQUENCE_SPEC
+diff --git a/gcc/configure b/gcc/configure
+index a8b531d8fae..6793d97820d 100755
+--- a/gcc/configure
++++ b/gcc/configure
+@@ -33420,6 +33420,12 @@ $as_echo "#define ENABLE_DEFAULT_SSP 1" >>confdefs.h
+ fi
+ 
+ 
++if echo " ${TARGET_CONFIGDIRS} " | grep " libatomic " > /dev/null 2>&1 ; then
++
++$as_echo "#define TARGET_PROVIDES_LIBATOMIC 1" >>confdefs.h
++
++fi
++
+ # Test for <sys/sdt.h> on the target.
+ 
+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking sys/sdt.h in the target C library" >&5
+diff --git a/gcc/configure.ac b/gcc/configure.ac
+index 77fab885a42..a6dd5786bd9 100644
+--- a/gcc/configure.ac
++++ b/gcc/configure.ac
+@@ -7011,6 +7011,11 @@ if test x$enable_default_ssp = xyes ; then
+ fi
+ AC_SUBST([enable_default_ssp])
+ 
++if echo " ${TARGET_CONFIGDIRS} " | grep " libatomic " > /dev/null 2>&1 ; then
++  AC_DEFINE(TARGET_PROVIDES_LIBATOMIC, 1,
++	    [Define if libatomic is built for the target])
++fi
++
+ # Test for <sys/sdt.h> on the target.
+ GCC_TARGET_TEMPLATE([HAVE_SYS_SDT_H])
+ AC_CACHE_CHECK([sys/sdt.h in the target C library], [gcc_cv_sys_sdt_h], [
+diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
+index 8ed5536365f..edf6c9f8684 100644
+--- a/gcc/doc/invoke.texi
++++ b/gcc/doc/invoke.texi
+@@ -206,7 +206,7 @@ in the following sections.
+ -fpermitted-flt-eval-methods=@var{standard}
+ -fplan9-extensions  -fsigned-bitfields  -funsigned-bitfields
+ -fsigned-char  -funsigned-char  -fstrict-flex-arrays[=@var{n}]
+--fsso-struct=@var{endianness}}
++-flink-libatomic -fsso-struct=@var{endianness}}
+ 
+ @item C++ Language Options
+ @xref{C++ Dialect Options,,Options Controlling C++ Dialect}.
+@@ -2899,6 +2899,10 @@ The @option{-fstrict_flex_arrays} option interacts with the
+ @option{-Wstrict-flex-arrays} option.  @xref{Warning Options}, for more
+ information.
+ 
++@opindex flink-libatomic
++@item -flink-libatomic
++Enable linking of libatomic if it's supported by target. Enabled by default.
++
+ @opindex fsso-struct
+ @item -fsso-struct=@var{endianness}
+ Set the default scalar storage order of structures and unions to the
+diff --git a/gcc/gcc.cc b/gcc/gcc.cc
+index 92c92996401..43d4c8763cb 100644
+--- a/gcc/gcc.cc
++++ b/gcc/gcc.cc
+@@ -980,6 +980,13 @@ proper position among the other output files.  */
+ 
+ /* Here is the spec for running the linker, after compiling all files.  */
+ 
++#if defined(TARGET_PROVIDES_LIBATOMIC) && defined(USE_LD_AS_NEEDED)
++#define LINK_LIBATOMIC_SPEC "%{!fno-link-libatomic:" LD_AS_NEEDED_OPTION \
++			    " -latomic " LD_NO_AS_NEEDED_OPTION "} "
++#else
++#define LINK_LIBATOMIC_SPEC ""
++#endif
++
+ /* This is overridable by the target in case they need to specify the
+    -lgcc and -lc order specially, yet not require them to override all
+    of LINK_COMMAND_SPEC.  */
+diff --git a/libatomic/Makefile.am b/libatomic/Makefile.am
+index efadd9dcd48..80bb6fbf477 100644
+--- a/libatomic/Makefile.am
++++ b/libatomic/Makefile.am
+@@ -69,7 +69,7 @@ libatomic_darwin_rpath += -Wl,-rpath,@loader_path
+ endif
+ 
+ libatomic_la_LDFLAGS = $(libatomic_version_info) $(libatomic_version_script) \
+-	$(lt_host_flags) $(libatomic_darwin_rpath)
++	-Wc,-fno-link-libatomic $(lt_host_flags) $(libatomic_darwin_rpath)
+ libatomic_la_SOURCES = gload.c gstore.c gcas.c gexch.c glfree.c lock.c init.c \
+ 	fenv.c fence.c flag.c
+ 
+@@ -162,6 +162,11 @@ libatomic_convenience_la_LIBADD = $(libatomic_la_LIBADD)
+ # when it is reloaded during the build of all-multi.
+ all-multi: $(libatomic_la_LIBADD)
+ 
++gcc_objdir = $(MULTIBUILDTOP)../../$(host_subdir)/gcc
++all: all-multi libatomic.la libatomic_convenience.la
++	$(INSTALL_DATA) .libs/libatomic.a $(gcc_objdir)$(MULTISUBDIR)/
++	chmod 644 $(gcc_objdir)$(MULTISUBDIR)/libatomic.a
++
+ # target overrides
+ -include $(tmake_file)
+ 
+diff --git a/libatomic/Makefile.in b/libatomic/Makefile.in
+index 9798e7c09e9..1d0494543d7 100644
+--- a/libatomic/Makefile.in
++++ b/libatomic/Makefile.in
+@@ -421,7 +421,7 @@ libatomic_version_info = -version-info $(libtool_VERSION)
+ @ENABLE_DARWIN_AT_RPATH_TRUE@	-Wc,-nodefaultrpaths \
+ @ENABLE_DARWIN_AT_RPATH_TRUE@	-Wl,-rpath,@loader_path
+ libatomic_la_LDFLAGS = $(libatomic_version_info) $(libatomic_version_script) \
+-	$(lt_host_flags) $(libatomic_darwin_rpath)
++	-Wc,-fno-link-libatomic $(lt_host_flags) $(libatomic_darwin_rpath)
+ 
+ libatomic_la_SOURCES = gload.c gstore.c gcas.c gexch.c glfree.c lock.c \
+ 	init.c fenv.c fence.c flag.c $(am__append_5)
+@@ -458,6 +458,7 @@ libatomic_la_LIBADD = $(foreach s,$(SIZES),$(addsuffix \
+ @ARCH_X86_64_TRUE@@HAVE_IFUNC_TRUE@IFUNC_OPTIONS = -mcx16 -mcx16
+ libatomic_convenience_la_SOURCES = $(libatomic_la_SOURCES)
+ libatomic_convenience_la_LIBADD = $(libatomic_la_LIBADD)
++gcc_objdir = $(MULTIBUILDTOP)../../$(host_subdir)/gcc
+ MULTISRCTOP = 
+ MULTIBUILDTOP = 
+ MULTIDIRS = 
+@@ -901,6 +902,9 @@ vpath % $(strip $(search_path))
+ # makefile fragments to avoid broken *.Ppo getting included into the Makefile
+ # when it is reloaded during the build of all-multi.
+ all-multi: $(libatomic_la_LIBADD)
++all: all-multi libatomic.la libatomic_convenience.la
++	$(INSTALL_DATA) .libs/libatomic.a $(gcc_objdir)$(MULTISUBDIR)/
++	chmod 644 $(gcc_objdir)$(MULTISUBDIR)/libatomic.a
+ 
+ # target overrides
+ -include $(tmake_file)
+diff --git a/libatomic/configure b/libatomic/configure
+index d579bab96f8..0a340276ca6 100755
+--- a/libatomic/configure
++++ b/libatomic/configure
+@@ -3415,6 +3415,26 @@ esac
+ # the wrong, non-multilib-adjusted value will be used in multilibs.
+ # As a side effect, we have to subst CFLAGS ourselves.
+ 
++# AC_PROG_CC sets CFLAGS to "-g -O2" by default (if unset), and
++# then compile conftests with default CFLAGS, leaving no place to temporarily
++# modify CFLAGS and restore them later. However we need to pass
++# -fno-link-libatomic in CFLAGS so conftests compiled in AC_PROG_CC don't fail.
++# Assert that CFLAGS is always set by user so the default setting of CFLAGS by
++# AC_PROG_CC won't be applicable anyway.
++if test -z "${CFLAGS}"; then
++  as_fn_error $? "CFLAGS must be set." "$LINENO" 5
++fi
++
++# In order to override CFLAGS_FOR_TARGET, all of our special flags go
++# in XCFLAGS.  But we need them in CFLAGS during configury.  So put them
++# in both places for now and restore CFLAGS at the end of config.
++save_CFLAGS="$CFLAGS"
++
++# Append -fno-link-libatomic to avoid automatically linking libatomic,
++# while building libatomic itself.
++XCFLAGS="$XCFLAGS -fno-link-libatomic"
++CFLAGS="$save_CFLAGS $XCFLAGS"
++
+ 
+ 
+ ac_ext=c
+@@ -4593,11 +4613,6 @@ fi
+ 
+ 
+ 
+-# In order to override CFLAGS_FOR_TARGET, all of our special flags go
+-# in XCFLAGS.  But we need them in CFLAGS during configury.  So put them
+-# in both places for now and restore CFLAGS at the end of config.
+-save_CFLAGS="$CFLAGS"
+-
+ # Find other programs we need.
+ if test -n "$ac_tool_prefix"; then
+   # Extract the first word of "${ac_tool_prefix}ar", so it can be a program name with args.
+@@ -11456,7 +11471,7 @@ else
+   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
+   lt_status=$lt_dlunknown
+   cat > conftest.$ac_ext <<_LT_EOF
+-#line 11459 "configure"
++#line 11474 "configure"
+ #include "confdefs.h"
+ 
+ #if HAVE_DLFCN_H
+@@ -11562,7 +11577,7 @@ else
+   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
+   lt_status=$lt_dlunknown
+   cat > conftest.$ac_ext <<_LT_EOF
+-#line 11565 "configure"
++#line 11580 "configure"
+ #include "confdefs.h"
+ 
+ #if HAVE_DLFCN_H
+diff --git a/libatomic/configure.ac b/libatomic/configure.ac
+index 32a2cdb13ae..23a9695be36 100644
+--- a/libatomic/configure.ac
++++ b/libatomic/configure.ac
+@@ -129,6 +129,26 @@ AC_SUBST(toolexeclibdir)
+ # the wrong, non-multilib-adjusted value will be used in multilibs.
+ # As a side effect, we have to subst CFLAGS ourselves.
+ 
++# AC_PROG_CC sets CFLAGS to "-g -O2" by default (if unset), and
++# then compile conftests with default CFLAGS, leaving no place to temporarily
++# modify CFLAGS and restore them later. However we need to pass
++# -fno-link-libatomic in CFLAGS so conftests compiled in AC_PROG_CC don't fail.
++# Assert that CFLAGS is always set by user so the default setting of CFLAGS by
++# AC_PROG_CC won't be applicable anyway.
++if test -z "${CFLAGS}"; then
++  AC_MSG_ERROR([CFLAGS must be set.])
++fi
++
++# In order to override CFLAGS_FOR_TARGET, all of our special flags go
++# in XCFLAGS.  But we need them in CFLAGS during configury.  So put them
++# in both places for now and restore CFLAGS at the end of config.
++save_CFLAGS="$CFLAGS"
++
++# Append -fno-link-libatomic to avoid automatically linking libatomic,
++# while building libatomic itself.
++XCFLAGS="$XCFLAGS -fno-link-libatomic"
++CFLAGS="$save_CFLAGS $XCFLAGS"
++
+ m4_rename([_AC_ARG_VAR_PRECIOUS],[real_PRECIOUS])
+ m4_define([_AC_ARG_VAR_PRECIOUS],[])
+ AC_PROG_CC
+@@ -137,11 +157,6 @@ m4_rename_force([real_PRECIOUS],[_AC_ARG_VAR_PRECIOUS])
+ 
+ AC_SUBST(CFLAGS)
+ 
+-# In order to override CFLAGS_FOR_TARGET, all of our special flags go
+-# in XCFLAGS.  But we need them in CFLAGS during configury.  So put them
+-# in both places for now and restore CFLAGS at the end of config.
+-save_CFLAGS="$CFLAGS"
+-
+ # Find other programs we need.
+ AC_CHECK_TOOL(AR, ar)
+ AC_CHECK_TOOL(NM, nm)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 666e4b2..2d01229 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 37	????
 
 	- 78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch
+	+ 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
 	+ 81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
 
 36	5 January 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-08 21:51 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-08 21:51 UTC (permalink / raw
  To: gentoo-commits
commit:     93975113f3b353a27dea263c60ee62b27894be9b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Jan  8 21:51:32 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jan  8 21:51:32 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=93975113
15.0.0: drop upstream 79_all_PR32491-fix-binutils-arm-check.patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../79_all_PR32491-fix-binutils-arm-check.patch    | 130 ---------------------
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 1 insertion(+), 130 deletions(-)
diff --git a/15.0.0/gentoo/79_all_PR32491-fix-binutils-arm-check.patch b/15.0.0/gentoo/79_all_PR32491-fix-binutils-arm-check.patch
deleted file mode 100644
index 290fb53..0000000
--- a/15.0.0/gentoo/79_all_PR32491-fix-binutils-arm-check.patch
+++ /dev/null
@@ -1,130 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/20241227214756.1059146-1-thiago.bauermann@linaro.org/
-
-From 4f033ebeb8efb96f4f164e33d2536d1d18316052 Mon Sep 17 00:00:00 2001
-Message-ID: <4f033ebeb8efb96f4f164e33d2536d1d18316052.1735466357.git.sam@gentoo.org>
-From: Thiago Jung Bauermann <thiago.bauermann@linaro.org>
-Date: Fri, 27 Dec 2024 18:47:56 -0300
-Subject: [PATCH] gcc/configure: Fix check for assembler section merging
- support on Arm
-
-In 32-bit Arm assembly, the @ character is the start of a comment so
-the section type needs to use the % character instead.
-
-configure.ac attempts to account for this difference by doing a second
-try when checking the assembler for section merging support.
-Unfortunately there is a bug: because the gcc_GAS_CHECK_FEATURE macro
-has a call to AC_CACHE_CHECK, it will actually skip the second try
-because the gcc_cv_as_shf_merge variable has already been set:
-
-  checking assembler for section merging support... no
-  checking assembler for section merging support... (cached) no
-
-Fix by using a separate variable for the second try, as is done in the
-check for COMDAT group support.
-
-This problem was noticed because the recent binutils commit
-d5cbf916be4a ("gas/ELF: also reject merge entity size being zero") caused
-gas to be stricter about mergeable sections without an entity size:
-
-configure:27013: checking assembler for section merging support
-configure:27022: /path/to/as   --fatal-warnings -o conftest.o conftest.s >&5
-conftest.s: Assembler messages:
-conftest.s:1: Warning: invalid merge / string entity size
-conftest.s: Error: 1 warning, treating warnings as errors
-configure:27025: $? = 1
-configure: failed program was
-.section .rodata.str, "aMS", @progbits, 1
-configure:27036: result: no
-
-In previous versions of gas the conftest.s program above was accepted
-and configure detected support for section merging.
-
-See also:
-https://linaro.atlassian.net/browse/GNU-1427
-https://sourceware.org/bugzilla/show_bug.cgi?id=32491
-
-Tested on armv8l-linux-gnueabihf.
-
-gcc/ChangeLog:
-	* configure.ac: Fix check for HAVE_GAS_SHF_MERGE on Arm targets.
-	* configure: Regenerate.
----
- gcc/configure    | 17 +++++++++--------
- gcc/configure.ac |  6 ++++--
- 2 files changed, 13 insertions(+), 10 deletions(-)
-
-diff --git a/gcc/configure b/gcc/configure
-index a8b531d8fae0..0bc33f0ede18 100755
---- a/gcc/configure
-+++ b/gcc/configure
-@@ -27038,12 +27038,12 @@ $as_echo "$gcc_cv_as_shf_merge" >&6; }
- 
- 
- if test $gcc_cv_as_shf_merge = no; then
--  { $as_echo "$as_me:${as_lineno-$LINENO}: checking assembler for section merging support" >&5
--$as_echo_n "checking assembler for section merging support... " >&6; }
--if ${gcc_cv_as_shf_merge+:} false; then :
-+  { $as_echo "$as_me:${as_lineno-$LINENO}: checking assembler for section merging support (%progbits)" >&5
-+$as_echo_n "checking assembler for section merging support (%progbits)... " >&6; }
-+if ${gcc_cv_as_shf_merge_percent+:} false; then :
-   $as_echo_n "(cached) " >&6
- else
--  gcc_cv_as_shf_merge=no
-+  gcc_cv_as_shf_merge_percent=no
-   if test x$gcc_cv_as != x; then
-     $as_echo '.section .rodata.str, "aMS", %progbits, 1' > conftest.s
-     if { ac_try='$gcc_cv_as $gcc_cv_as_flags --fatal-warnings -o conftest.o conftest.s >&5'
-@@ -27053,7 +27053,7 @@ else
-   $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
-   test $ac_status = 0; }; }
-     then
--	gcc_cv_as_shf_merge=yes
-+	gcc_cv_as_shf_merge_percent=yes
-     else
-       echo "configure: failed program was" >&5
-       cat conftest.s >&5
-@@ -27061,14 +27061,15 @@ else
-     rm -f conftest.o conftest.s
-   fi
- fi
--{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gcc_cv_as_shf_merge" >&5
--$as_echo "$gcc_cv_as_shf_merge" >&6; }
-+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gcc_cv_as_shf_merge_percent" >&5
-+$as_echo "$gcc_cv_as_shf_merge_percent" >&6; }
- 
- 
- fi
- 
- cat >>confdefs.h <<_ACEOF
--#define HAVE_GAS_SHF_MERGE `if test $gcc_cv_as_shf_merge = yes; then echo 1; else echo 0; fi`
-+#define HAVE_GAS_SHF_MERGE `if test $gcc_cv_as_shf_merge = yes \
-+    || test $gcc_cv_as_shf_merge_percent = yes; then echo 1; else echo 0; fi`
- _ACEOF
- 
- 
-diff --git a/gcc/configure.ac b/gcc/configure.ac
-index 77fab885a428..1407c86e355b 100644
---- a/gcc/configure.ac
-+++ b/gcc/configure.ac
-@@ -3612,12 +3612,14 @@ gcc_GAS_CHECK_FEATURE(section merging support, gcc_cv_as_shf_merge,
-  [--fatal-warnings],
-  [.section .rodata.str, "aMS", @progbits, 1])
- if test $gcc_cv_as_shf_merge = no; then
--  gcc_GAS_CHECK_FEATURE(section merging support, gcc_cv_as_shf_merge,
-+  gcc_GAS_CHECK_FEATURE(section merging support (%progbits),
-+    gcc_cv_as_shf_merge_percent,
-     [--fatal-warnings],
-     [.section .rodata.str, "aMS", %progbits, 1])
- fi
- AC_DEFINE_UNQUOTED(HAVE_GAS_SHF_MERGE,
--  [`if test $gcc_cv_as_shf_merge = yes; then echo 1; else echo 0; fi`],
-+  [`if test $gcc_cv_as_shf_merge = yes \
-+    || test $gcc_cv_as_shf_merge_percent = yes; then echo 1; else echo 0; fi`],
- [Define 0/1 if your assembler supports marking sections with SHF_MERGE flag.])
- 
- gcc_GAS_CHECK_FEATURE([COMDAT group support (GNU as)],
-
-base-commit: 4da027d87eabd9a6cb0f5c1ed7ee10540501c7a3
--- 
-2.47.1
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 2d01229..7b6d0a6 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 37	????
 
 	- 78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch
+	- 79_all_PR32491-fix-binutils-arm-check.patch
 	+ 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
 	+ 81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-11 12:53 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-11 12:53 UTC (permalink / raw
  To: gentoo-commits
commit:     363d9cf8b9fb665334e166cdaf515bb28dbc2880
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 11 12:52:36 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jan 11 12:52:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=363d9cf8
15.0.0: refresh C23 "too many/few" arguments patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...ovements-to-too-few-many-arguments-errors.patch | 233 +++++++++++++++++----
 1 file changed, 197 insertions(+), 36 deletions(-)
diff --git a/15.0.0/gentoo/77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch b/15.0.0/gentoo/77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
index 8688ac1..b1e83b5 100644
--- a/15.0.0/gentoo/77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
+++ b/15.0.0/gentoo/77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
@@ -1,11 +1,165 @@
-https://inbox.sourceware.org/gcc-patches/20241219234019.722392-1-dmalcolm@redhat.com/
+https://inbox.sourceware.org/gcc-patches/f34fdf57159821af93c7da1643edfa4796a77ad4.camel@redhat.com/#t
 
-From b0525913499d305c2116e31bc6505ed67e87cf19 Mon Sep 17 00:00:00 2001
-Message-ID: <b0525913499d305c2116e31bc6505ed67e87cf19.1734659653.git.sam@gentoo.org>
+From 595638c60e39f513301e34afdf14b04247634838 Mon Sep 17 00:00:00 2001
+Message-ID: <595638c60e39f513301e34afdf14b04247634838.1736599921.git.sam@gentoo.org>
 From: David Malcolm <dmalcolm@redhat.com>
-Date: Thu, 19 Dec 2024 18:40:19 -0500
+Date: Fri, 10 Jan 2025 13:47:43 -0500
 Subject: [PATCH] c/c++: UX improvements to 'too {few,many} arguments' errors
  [PR118112]
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+On Thu, 2025-01-09 at 22:28 -0500, David Malcolm wrote:
+> On Thu, 2025-01-09 at 21:15 -0500, Jason Merrill wrote:
+> > On 1/9/25 7:00 PM, David Malcolm wrote:
+> > > On Thu, 2025-01-09 at 14:21 -0500, Jason Merrill wrote:
+> > >
+> > > Thanks for taking a look...
+> > >
+> > > > > On 1/9/25 2:11 PM, David Malcolm wrote:
+> > > > >
+> > > > > @@ -4743,7 +4769,38 @@ convert_arguments (tree typelist,
+> > > > > vec<tree,
+> > > > > va_gc> **values, tree fndecl,
+> > > > >          if (typetail && typetail != void_list_node)
+> > > > >    	{
+> > > > >    	  if (complain & tf_error)
+> > > > > -	    error_args_num (input_location, fndecl,
+> > > > > /*too_many_p=*/false);
+> > > > > +	    {
+> > > > > +	      /* Not enough args.
+> > > > > +		 Determine minimum number of arguments
+> > > > > required.  */
+> > > > > +	      int min_expected_num = 0;
+> > > > > +	      bool at_least_p = false;
+> > > > > +	      tree iter = typelist;
+> > > > > +	      while (true)
+> > > > > +		{
+> > > > > +		  if (!iter)
+> > > > > +		    {
+> > > > > +		      /* Variadic arguments; stop
+> > > > > iterating. 
+> > > > > */
+> > > > > +		      at_least_p = true;
+> > > > > +		      break;
+> > > > > +		    }
+> > > > > +		  if (iter == void_list_node)
+> > > > > +		    /* End of arguments; stop iterating.  */
+> > > > > +		    break;
+> > > > > +		  if (fndecl && TREE_PURPOSE (iter)
+> > > > > +		      && TREE_CODE (TREE_PURPOSE (iter)) !=
+> > > > > DEFERRED_PARSE)
+> > > > >
+> > > >
+> > > > Why are you checking DEFERRED_PARSE?  That indicates a default
+> > > > argument,
+> > > > even if it isn't parsed yet.  For that case we should get the
+> > > > error
+> > > > in
+> > > > convert_default_arg rather than pretend there's no default
+> > > > argument.
+> > >
+> > > I confess that the check for DEFERRED_PARSE was a rather mindless
+> > > copy
+> > > and paste by me from the "See if there are default arguments that
+> > > can be
+> > > used" logic earlier in the function.
+> > >
+> > > I've removed it in the latest version of the patch.
+> > >  
+> > > > > +		    {
+> > > > > +		      /* Found a default argument; skip this
+> > > > > one when
+> > > > > +			 counting minimum required.  */
+> > > > > +		      at_least_p = true;
+> > > > > +		      iter = TREE_CHAIN (iter);
+> > > > > +		      continue;
+> > > >
+> > > > We could break here, once you have a default arg the rest of
+> > > > the
+> > > > parms
+> > > > need to have them as well.
+> > >
+> > > Indeed; I've updated this in the latest version of the patch, so
+> > > we break out as soon as we see an arg with a non-null
+> > > TREE_PURPOSE.
+> > >
+> > > >
+> > > > > +		    }
+> > > > > +		  ++min_expected_num;
+> > > > > +		  iter = TREE_CHAIN (iter);
+> > > > > +		}
+> > > > > +	      error_args_num (input_location, fndecl,
+> > > > > +			      min_expected_num, actual_num,
+> > > > > at_least_p);
+> > > > > +	    }
+> > > > >    	  return -1;
+> > > > >    	}
+> > >
+> > > Here's a v3 version of the patch, which is currently going
+> > > through
+> > > my tester.
+> > >
+> > > OK for trunk if it passes bootstrap®rtesting?
+> >
+> > OK.
+>
+> Thanks.  However, it turns out that I may have misspoke, and the v2
+> patch might have been the correct approach: if we bail out on the
+> first
+> arg with a TREE_PURPOSE then in
+> gcc/testsuite/g++.dg/cpp0x/variadic169.C
+>
+>    1   │ // DR 2233
+>    2   │ // { dg-do compile { target c++11 } }
+>    3   │
+>    4   │ template<typename ...T> void f(int n = 0, T ...t);
+>    5   │
+>    6   │ int main()
+>    7   │ {
+>    8   │   f<int>();         // { dg-error "too few arguments to
+> function '\[^\n\r\]*'; expected at least 1, have 0" }
+>    9   │ }
+>
+> we instead emit the nonsensical "expected at least 0, have 0":
+>
+> error: too few arguments to function ‘void f(int, T ...) [with T =
+> {int}]’; expected at least 0, have 0
+>     8 |   f<int>();                     // { dg-error "too few
+> arguments to function '\[^\n\r\]*'; expected at least 1, have 0" }
+>       |   ~~~~~~^~
+> ../../src/gcc/testsuite/g++.dg/cpp0x/variadic169.C:4:30: note:
+> declared
+> here
+>     4 | template<typename ...T> void f(int n = 0, T ...t);
+>       |                              ^
+>
+> whereas with the v2 patch we count the trailing arg after the default
+> arg, and we emit "expected at least 1, have 0", which seems correct
+> to
+> me.
+>
+> I'm testing a version of the patch that continues to iterate after a
+> TREE_PURPOSE (as v2, but but dropping the check on DEFERRED_PARSE).
+>
+> Thanks
+> Dave
+
+Hi Jason
+
+Here's an updated version of the patch which drops the check on
+DEFERRED_PARSE, but continues to iterate on TREE_PURPOSE, for dealing
+with the case of explicit template args where default args are followed
+by missing mandatory args (the code above mentions DR777, so I
+referenced that).
+
+Successfully bootstrapped & regrtested on x86_64-pc-linux-gnu.
+
+Are the C++ parts OK for trunk?
+
+Thanks
+Dave
 
 Consider this case of a bad call to a callback function (perhaps
 due to C23 changing the meaning of () in function decls):
@@ -82,9 +236,6 @@ s.c:1:6: note: declared here
     1 | void callee (const char *, ...);
       |      ^~~~~~
 
-Successfully bootstrapped & regrtested on x86_64-pc-linux-gnu.
-OK for trunk?
-
 gcc/c/ChangeLog:
 	PR c/118112
 	* c-typeck.cc (inform_declaration): Add "function_expr" param and
@@ -122,19 +273,19 @@ gcc/testsuite/ChangeLog:
 
 Signed-off-by: David Malcolm <dmalcolm@redhat.com>
 ---
- gcc/c/c-typeck.cc                             | 77 ++++++++++++---
- gcc/cp/typeck.cc                              | 94 ++++++++++++++----
- .../c-c++-common/too-few-arguments.c          | 38 ++++++++
- .../c-c++-common/too-many-arguments.c         | 96 +++++++++++++++++++
- gcc/testsuite/g++.dg/cpp0x/variadic169.C      |  2 +-
- gcc/testsuite/g++.dg/modules/macloc-1_c.C     |  4 +-
- gcc/testsuite/g++.dg/modules/macloc-1_d.C     |  4 +-
- 7 files changed, 280 insertions(+), 35 deletions(-)
+ gcc/c/c-typeck.cc                             |  77 +++++++++++--
+ gcc/cp/typeck.cc                              | 104 ++++++++++++++----
+ .../c-c++-common/too-few-arguments.c          |  38 +++++++
+ .../c-c++-common/too-many-arguments.c         |  96 ++++++++++++++++
+ gcc/testsuite/g++.dg/cpp0x/variadic169.C      |   2 +-
+ gcc/testsuite/g++.dg/modules/macloc-1_c.C     |   4 +-
+ gcc/testsuite/g++.dg/modules/macloc-1_d.C     |   4 +-
+ 7 files changed, 287 insertions(+), 38 deletions(-)
  create mode 100644 gcc/testsuite/c-c++-common/too-few-arguments.c
  create mode 100644 gcc/testsuite/c-c++-common/too-many-arguments.c
 
 diff --git a/gcc/c/c-typeck.cc b/gcc/c/c-typeck.cc
-index 9756edaae084..fff2bba06954 100644
+index 6e40f7edf02a..cd9290160d7a 100644
 --- a/gcc/c/c-typeck.cc
 +++ b/gcc/c/c-typeck.cc
 @@ -3737,14 +3737,30 @@ build_function_call (location_t loc, tree function, tree params)
@@ -284,7 +435,7 @@ index 9756edaae084..fff2bba06954 100644
  
    return error_args ? -1 : (int) parmnum;
 diff --git a/gcc/cp/typeck.cc b/gcc/cp/typeck.cc
-index 964e549a6122..2966931ca8c1 100644
+index 3e0d71102abd..a8580eddd397 100644
 --- a/gcc/cp/typeck.cc
 +++ b/gcc/cp/typeck.cc
 @@ -59,7 +59,7 @@ static tree get_delta_difference (tree, tree, bool, bool, tsubst_flags_t);
@@ -296,14 +447,17 @@ index 964e549a6122..2966931ca8c1 100644
  static int convert_arguments (tree, vec<tree, va_gc> **, tree, int,
                                tsubst_flags_t);
  static bool is_std_move_p (tree);
-@@ -4533,11 +4533,16 @@ cp_build_function_call_vec (tree function, vec<tree, va_gc> **params,
+@@ -4535,11 +4535,19 @@ cp_build_function_call_vec (tree function, vec<tree, va_gc> **params,
  }
  \f
  /* Subroutine of convert_arguments.
 -   Print an error message about a wrong number of arguments.  */
 +   Print an error message about a wrong number of arguments.
 +   If AT_LEAST_P is true, then EXPECTED_NUM is the minimum number
-+   of expected arguments.  */
++   of expected arguments, otherwise EXPECTED_NUM is the exact number
++   of expected arguments.
++   ACTUAL_NUM is the actual number of arguments that were explicitly
++   passed at the callsite (i.e. not counting default arguments).  */
  
  static void
 -error_args_num (location_t loc, tree fndecl, bool too_many_p)
@@ -315,7 +469,7 @@ index 964e549a6122..2966931ca8c1 100644
    if (fndecl)
      {
        auto_diagnostic_group d;
-@@ -4548,22 +4553,28 @@ error_args_num (location_t loc, tree fndecl, bool too_many_p)
+@@ -4550,22 +4558,28 @@ error_args_num (location_t loc, tree fndecl, bool too_many_p)
  		  == DECL_NAME (TYPE_NAME (DECL_CONTEXT (fndecl)))))
  	    error_at (loc,
  		      too_many_p
@@ -353,7 +507,7 @@ index 964e549a6122..2966931ca8c1 100644
        if (!DECL_IS_UNDECLARED_BUILTIN (fndecl))
  	inform (DECL_SOURCE_LOCATION (fndecl), "declared here");
      }
-@@ -4572,12 +4583,19 @@ error_args_num (location_t loc, tree fndecl, bool too_many_p)
+@@ -4574,12 +4588,19 @@ error_args_num (location_t loc, tree fndecl, bool too_many_p)
        if (c_dialect_objc ()  &&  objc_message_selector ())
  	error_at (loc,
  		  too_many_p
@@ -378,30 +532,34 @@ index 964e549a6122..2966931ca8c1 100644
      }
  }
  
-@@ -4607,6 +4625,10 @@ convert_arguments (tree typelist, vec<tree, va_gc> **values, tree fndecl,
+@@ -4609,9 +4630,11 @@ convert_arguments (tree typelist, vec<tree, va_gc> **values, tree fndecl,
    /* Argument passing is always copy-initialization.  */
    flags |= LOOKUP_ONLYCONVERTING;
  
+-  for (i = 0, typetail = typelist;
+-       i < vec_safe_length (*values);
+-       i++)
 +  /* Preserve actual number of arguments passed (without counting default
 +     args), in case we need to complain about too many/few.  */
-+  int actual_num = vec_safe_length (*values);
++  const unsigned actual_num = vec_safe_length (*values);
 +
-   for (i = 0, typetail = typelist;
-        i < vec_safe_length (*values);
-        i++)
-@@ -4621,7 +4643,10 @@ convert_arguments (tree typelist, vec<tree, va_gc> **values, tree fndecl,
++  for (i = 0, typetail = typelist; i < actual_num; i++)
+     {
+       tree type = typetail ? TREE_VALUE (typetail) : 0;
+       tree val = (**values)[i];
+@@ -4623,7 +4646,10 @@ convert_arguments (tree typelist, vec<tree, va_gc> **values, tree fndecl,
  	{
            if (complain & tf_error)
              {
 -	      error_args_num (input_location, fndecl, /*too_many_p=*/true);
 +	      /* Too many args.  */
-+	      int expected_num = i;
-+	      error_args_num (input_location, fndecl, expected_num, actual_num,
-+			      false);
++	      error_args_num (input_location, fndecl,
++			      /*expected_num=*/i, actual_num,
++			      /*at_least_p=*/false);
                return i;
              }
            else
-@@ -4743,7 +4768,38 @@ convert_arguments (tree typelist, vec<tree, va_gc> **values, tree fndecl,
+@@ -4745,7 +4771,41 @@ convert_arguments (tree typelist, vec<tree, va_gc> **values, tree fndecl,
        if (typetail && typetail != void_list_node)
  	{
  	  if (complain & tf_error)
@@ -423,11 +581,14 @@ index 964e549a6122..2966931ca8c1 100644
 +		  if (iter == void_list_node)
 +		    /* End of arguments; stop iterating.  */
 +		    break;
-+		  if (fndecl && TREE_PURPOSE (iter)
-+		      && TREE_CODE (TREE_PURPOSE (iter)) != DEFERRED_PARSE)
++		  if (fndecl && TREE_PURPOSE (iter))
 +		    {
 +		      /* Found a default argument; skip this one when
-+			 counting minimum required.  */
++			 counting minimum required, but there might
++			 be non-default arguments left to count:
++			 after DR777, with explicit template args we can
++			 end up with a default argument followed by
++			 no default argument.  */
 +		      at_least_p = true;
 +		      iter = TREE_CHAIN (iter);
 +		      continue;
@@ -624,7 +785,7 @@ index 282a31c4a2d1..56c001fc3f83 100644
 +// { dg-regexp "\[^\n]*macloc-1_d.C:8:6: error: too many arguments to function 'int me@agnes\\(\\)'; expected 0, have 1\nIn module agnes, imported at \[^\n]*macloc-1_d.C:4:\n\[^\n]*macloc-1_a.C:11:12: note: declared here\n\[^\n]*macloc-1_a.C:8:20: note: in definition of macro 'BOB'\n" }
 +// { dg-regexp "\[^\n]*macloc-1_d.C:9:7: error: too many arguments to function 'void gru@edith\\(\\)'; expected 0, have 1\nIn module edith, imported at \[^\n]*macloc-1_d.C:3:\n\[^\n]*macloc-1_b.C:10:20: note: declared here\n\[^\n]*macloc-1_b.C:6:19: note: in definition of macro 'STUART'\n" }
 
-base-commit: b11e85adbfdb02bc7743098d358a5ea362648ca1
+base-commit: 65286465b94cba6ee3d59edbc771bef0088ac46e
 -- 
-2.47.1
+2.48.0
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-12 18:53 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-12 18:53 UTC (permalink / raw
  To: gentoo-commits
commit:     f6bd42a6cd7c3b5f94521de22765b50159531e8b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jan 12 18:53:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jan 12 18:53:49 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=f6bd42a6
15.0.0: drop upstream 77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
Now upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...ovements-to-too-few-many-arguments-errors.patch | 791 ---------------------
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 1 insertion(+), 791 deletions(-)
diff --git a/15.0.0/gentoo/77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch b/15.0.0/gentoo/77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
deleted file mode 100644
index b1e83b5..0000000
--- a/15.0.0/gentoo/77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
+++ /dev/null
@@ -1,791 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/f34fdf57159821af93c7da1643edfa4796a77ad4.camel@redhat.com/#t
-
-From 595638c60e39f513301e34afdf14b04247634838 Mon Sep 17 00:00:00 2001
-Message-ID: <595638c60e39f513301e34afdf14b04247634838.1736599921.git.sam@gentoo.org>
-From: David Malcolm <dmalcolm@redhat.com>
-Date: Fri, 10 Jan 2025 13:47:43 -0500
-Subject: [PATCH] c/c++: UX improvements to 'too {few,many} arguments' errors
- [PR118112]
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-On Thu, 2025-01-09 at 22:28 -0500, David Malcolm wrote:
-> On Thu, 2025-01-09 at 21:15 -0500, Jason Merrill wrote:
-> > On 1/9/25 7:00 PM, David Malcolm wrote:
-> > > On Thu, 2025-01-09 at 14:21 -0500, Jason Merrill wrote:
-> > >
-> > > Thanks for taking a look...
-> > >
-> > > > > On 1/9/25 2:11 PM, David Malcolm wrote:
-> > > > >
-> > > > > @@ -4743,7 +4769,38 @@ convert_arguments (tree typelist,
-> > > > > vec<tree,
-> > > > > va_gc> **values, tree fndecl,
-> > > > >          if (typetail && typetail != void_list_node)
-> > > > >    	{
-> > > > >    	  if (complain & tf_error)
-> > > > > -	    error_args_num (input_location, fndecl,
-> > > > > /*too_many_p=*/false);
-> > > > > +	    {
-> > > > > +	      /* Not enough args.
-> > > > > +		 Determine minimum number of arguments
-> > > > > required.  */
-> > > > > +	      int min_expected_num = 0;
-> > > > > +	      bool at_least_p = false;
-> > > > > +	      tree iter = typelist;
-> > > > > +	      while (true)
-> > > > > +		{
-> > > > > +		  if (!iter)
-> > > > > +		    {
-> > > > > +		      /* Variadic arguments; stop
-> > > > > iterating. 
-> > > > > */
-> > > > > +		      at_least_p = true;
-> > > > > +		      break;
-> > > > > +		    }
-> > > > > +		  if (iter == void_list_node)
-> > > > > +		    /* End of arguments; stop iterating.  */
-> > > > > +		    break;
-> > > > > +		  if (fndecl && TREE_PURPOSE (iter)
-> > > > > +		      && TREE_CODE (TREE_PURPOSE (iter)) !=
-> > > > > DEFERRED_PARSE)
-> > > > >
-> > > >
-> > > > Why are you checking DEFERRED_PARSE?  That indicates a default
-> > > > argument,
-> > > > even if it isn't parsed yet.  For that case we should get the
-> > > > error
-> > > > in
-> > > > convert_default_arg rather than pretend there's no default
-> > > > argument.
-> > >
-> > > I confess that the check for DEFERRED_PARSE was a rather mindless
-> > > copy
-> > > and paste by me from the "See if there are default arguments that
-> > > can be
-> > > used" logic earlier in the function.
-> > >
-> > > I've removed it in the latest version of the patch.
-> > >  
-> > > > > +		    {
-> > > > > +		      /* Found a default argument; skip this
-> > > > > one when
-> > > > > +			 counting minimum required.  */
-> > > > > +		      at_least_p = true;
-> > > > > +		      iter = TREE_CHAIN (iter);
-> > > > > +		      continue;
-> > > >
-> > > > We could break here, once you have a default arg the rest of
-> > > > the
-> > > > parms
-> > > > need to have them as well.
-> > >
-> > > Indeed; I've updated this in the latest version of the patch, so
-> > > we break out as soon as we see an arg with a non-null
-> > > TREE_PURPOSE.
-> > >
-> > > >
-> > > > > +		    }
-> > > > > +		  ++min_expected_num;
-> > > > > +		  iter = TREE_CHAIN (iter);
-> > > > > +		}
-> > > > > +	      error_args_num (input_location, fndecl,
-> > > > > +			      min_expected_num, actual_num,
-> > > > > at_least_p);
-> > > > > +	    }
-> > > > >    	  return -1;
-> > > > >    	}
-> > >
-> > > Here's a v3 version of the patch, which is currently going
-> > > through
-> > > my tester.
-> > >
-> > > OK for trunk if it passes bootstrap®rtesting?
-> >
-> > OK.
->
-> Thanks.  However, it turns out that I may have misspoke, and the v2
-> patch might have been the correct approach: if we bail out on the
-> first
-> arg with a TREE_PURPOSE then in
-> gcc/testsuite/g++.dg/cpp0x/variadic169.C
->
->    1   │ // DR 2233
->    2   │ // { dg-do compile { target c++11 } }
->    3   │
->    4   │ template<typename ...T> void f(int n = 0, T ...t);
->    5   │
->    6   │ int main()
->    7   │ {
->    8   │   f<int>();         // { dg-error "too few arguments to
-> function '\[^\n\r\]*'; expected at least 1, have 0" }
->    9   │ }
->
-> we instead emit the nonsensical "expected at least 0, have 0":
->
-> error: too few arguments to function ‘void f(int, T ...) [with T =
-> {int}]’; expected at least 0, have 0
->     8 |   f<int>();                     // { dg-error "too few
-> arguments to function '\[^\n\r\]*'; expected at least 1, have 0" }
->       |   ~~~~~~^~
-> ../../src/gcc/testsuite/g++.dg/cpp0x/variadic169.C:4:30: note:
-> declared
-> here
->     4 | template<typename ...T> void f(int n = 0, T ...t);
->       |                              ^
->
-> whereas with the v2 patch we count the trailing arg after the default
-> arg, and we emit "expected at least 1, have 0", which seems correct
-> to
-> me.
->
-> I'm testing a version of the patch that continues to iterate after a
-> TREE_PURPOSE (as v2, but but dropping the check on DEFERRED_PARSE).
->
-> Thanks
-> Dave
-
-Hi Jason
-
-Here's an updated version of the patch which drops the check on
-DEFERRED_PARSE, but continues to iterate on TREE_PURPOSE, for dealing
-with the case of explicit template args where default args are followed
-by missing mandatory args (the code above mentions DR777, so I
-referenced that).
-
-Successfully bootstrapped & regrtested on x86_64-pc-linux-gnu.
-
-Are the C++ parts OK for trunk?
-
-Thanks
-Dave
-
-Consider this case of a bad call to a callback function (perhaps
-due to C23 changing the meaning of () in function decls):
-
-struct p {
-        int (*bar)();
-};
-
-void baz() {
-    struct p q;
-    q.bar(1);
-}
-
-Before this patch the C frontend emits:
-
-t.c: In function 'baz':
-t.c:7:5: error: too many arguments to function 'q.bar'
-    7 |     q.bar(1);
-      |     ^
-
-and the C++ frontend emits:
-
-t.c: In function 'void baz()':
-t.c:7:10: error: too many arguments to function
-    7 |     q.bar(1);
-      |     ~~~~~^~~
-
-neither of which give the user much help in terms of knowing what
-was expected, and where the relevant declaration is.
-
-With this patch the C frontend emits:
-
-t.c: In function 'baz':
-t.c:7:5: error: too many arguments to function 'q.bar'; expected 0, have 1
-    7 |     q.bar(1);
-      |     ^     ~
-t.c:2:15: note: declared here
-    2 |         int (*bar)();
-      |               ^~~
-
-(showing the expected vs actual counts, the pertinent field decl, and
-underlining the first extraneous argument at the callsite)
-
-and the C++ frontend emits:
-
-t.c: In function 'void baz()':
-t.c:7:10: error: too many arguments to function; expected 0, have 1
-    7 |     q.bar(1);
-      |     ~~~~~^~~
-
-(showing the expected vs actual counts; the other data was not accessible
-without a more invasive patch)
-
-Similarly, the patch also updates the "too few arguments" case to also
-show expected vs actual counts.  Doing so requires a tweak to the
-wording to say "at least" for the case of variadic fns, and for C++ fns
-with default args, where e.g. previously the C FE emitted:
-
-s.c: In function 'test':
-s.c:5:3: error: too few arguments to function 'callee'
-    5 |   callee ();
-      |   ^~~~~~
-s.c:1:6: note: declared here
-    1 | void callee (const char *, ...);
-      |      ^~~~~~
-
-with this patch it emits:
-
-s.c: In function 'test':
-s.c:5:3: error: too few arguments to function 'callee'; expected at least 1, have 0
-    5 |   callee ();
-      |   ^~~~~~
-s.c:1:6: note: declared here
-    1 | void callee (const char *, ...);
-      |      ^~~~~~
-
-gcc/c/ChangeLog:
-	PR c/118112
-	* c-typeck.cc (inform_declaration): Add "function_expr" param and
-	use it for cases where we couldn't show the function decl to show
-	field decls for callbacks.
-	(build_function_call_vec): Add missing auto_diagnostic_group.
-	Update for new param of inform_declaration.
-	(convert_arguments): Likewise.  For the "too many arguments" case
-	add the expected vs actual counts to the message, and if we have
-	it, add the location_t of the first surplus param as a secondary
-	location within the diagnostic.  For the "too few arguments" case,
-	determine the minimum number of arguments required and add the
-	expected vs actual counts to the message, tweaking it to "at least"
-	for variadic functions.
-
-gcc/cp/ChangeLog:
-	PR c/118112
-	* typeck.cc (error_args_num): Add params "expected_num",
-	"actual_num", and "at_least_p".  Compute "too_many_p" from these
-	rather than have it be a param.  Add expected vs actual counts to
-	the messages and tweak them for the "at least" case.
-	(convert_arguments): Update calls to error_args_num to pass in
-	expected vs actual number, and the "at_least_p", determining this
-	for the "too few" case.
-
-gcc/testsuite/ChangeLog:
-	PR c/118112
-	* c-c++-common/too-few-arguments.c: New test.
-	* c-c++-common/too-many-arguments.c: New test.
-	* g++.dg/cpp0x/variadic169.C: Verify the reported expected vs
-	actual argument counts.
-	* g++.dg/modules/macloc-1_c.C: Update regexp for addition of param
-	counts to error message.
-	* g++.dg/modules/macloc-1_d.C: Likewise.
-
-Signed-off-by: David Malcolm <dmalcolm@redhat.com>
----
- gcc/c/c-typeck.cc                             |  77 +++++++++++--
- gcc/cp/typeck.cc                              | 104 ++++++++++++++----
- .../c-c++-common/too-few-arguments.c          |  38 +++++++
- .../c-c++-common/too-many-arguments.c         |  96 ++++++++++++++++
- gcc/testsuite/g++.dg/cpp0x/variadic169.C      |   2 +-
- gcc/testsuite/g++.dg/modules/macloc-1_c.C     |   4 +-
- gcc/testsuite/g++.dg/modules/macloc-1_d.C     |   4 +-
- 7 files changed, 287 insertions(+), 38 deletions(-)
- create mode 100644 gcc/testsuite/c-c++-common/too-few-arguments.c
- create mode 100644 gcc/testsuite/c-c++-common/too-many-arguments.c
-
-diff --git a/gcc/c/c-typeck.cc b/gcc/c/c-typeck.cc
-index 6e40f7edf02a..cd9290160d7a 100644
---- a/gcc/c/c-typeck.cc
-+++ b/gcc/c/c-typeck.cc
-@@ -3737,14 +3737,30 @@ build_function_call (location_t loc, tree function, tree params)
-   return ret;
- }
- 
--/* Give a note about the location of the declaration of DECL.  */
-+/* Give a note about the location of the declaration of DECL,
-+   or, failing that, a pertinent declaration for FUNCTION_EXPR.  */
- 
- static void
--inform_declaration (tree decl)
-+inform_declaration (tree decl, tree function_expr)
- {
-   if (decl && (TREE_CODE (decl) != FUNCTION_DECL
- 	       || !DECL_IS_UNDECLARED_BUILTIN (decl)))
-     inform (DECL_SOURCE_LOCATION (decl), "declared here");
-+  else if (function_expr)
-+    switch (TREE_CODE (function_expr))
-+      {
-+      default:
-+	break;
-+      case COMPONENT_REF:
-+	/* Show the decl of the pertinent field (e.g. for callback
-+	   fields in a struct.  */
-+	{
-+	  tree field_decl = TREE_OPERAND (function_expr, 1);
-+	  if (location_t loc = DECL_SOURCE_LOCATION (field_decl))
-+	    inform (loc, "declared here");
-+	}
-+	break;
-+      }
- }
- 
- /* C implementation of callback for use when checking param types.  */
-@@ -3819,10 +3835,11 @@ build_function_call_vec (location_t loc, vec<location_t> arg_loc,
- 		  function);
-       else if (DECL_P (function))
- 	{
-+	  auto_diagnostic_group d;
- 	  error_at (loc,
- 		    "called object %qD is not a function or function pointer",
- 		    function);
--	  inform_declaration (function);
-+	  inform_declaration (function, NULL_TREE);
- 	}
-       else
- 	error_at (loc,
-@@ -4276,25 +4293,37 @@ convert_arguments (location_t loc, vec<location_t> arg_loc, tree fntype,
- 
-       if (type == void_type_node)
- 	{
-+	  auto_diagnostic_group d;
-+	  int num_expected = parmnum;
-+	  int num_actual = values->length ();
-+	  gcc_rich_location rich_loc (loc);
-+	  if (ploc != input_location)
-+	    rich_loc.add_range (ploc);
- 	  if (selector)
--	    error_at (loc, "too many arguments to method %qE", selector);
-+	    error_at (&rich_loc,
-+		      "too many arguments to method %qE; expected %i, have %i",
-+		      selector, num_expected, num_actual);
- 	  else
--	    error_at (loc, "too many arguments to function %qE", function);
--	  inform_declaration (fundecl);
-+	    error_at (&rich_loc,
-+		      "too many arguments to function %qE; expected %i, have %i",
-+		      function, num_expected, num_actual);
-+	  inform_declaration (fundecl, function);
- 	  return error_args ? -1 : (int) parmnum;
- 	}
- 
-       if (builtin_type == void_type_node)
- 	{
-+	  auto_diagnostic_group d;
- 	  if (warning_at (loc, OPT_Wbuiltin_declaration_mismatch,
- 			  "too many arguments to built-in function %qE "
- 			  "expecting %d", function, parmnum))
--	    inform_declaration (fundecl);
-+	    inform_declaration (fundecl, function);
- 	  builtin_typetail = NULL_TREE;
- 	}
- 
-       if (!typetail && parmnum == 0 && !TYPE_NO_NAMED_ARGS_STDARG_P (fntype))
- 	{
-+	  auto_diagnostic_group d;
- 	  bool warned;
- 	  if (selector)
- 	    warned = warning_at (loc, OPT_Wdeprecated_non_prototype,
-@@ -4307,7 +4336,7 @@ convert_arguments (location_t loc, vec<location_t> arg_loc, tree fntype,
- 				 " for function %qE declared without parameters",
- 				 function);
- 	  if (warned)
--	    inform_declaration (fundecl);
-+	    inform_declaration (fundecl, function);
- 	}
- 
-       if (selector && argnum > 2)
-@@ -4437,8 +4466,33 @@ convert_arguments (location_t loc, vec<location_t> arg_loc, tree fntype,
- 
-   if (typetail != NULL_TREE && TREE_VALUE (typetail) != void_type_node)
-     {
--      error_at (loc, "too few arguments to function %qE", function);
--      inform_declaration (fundecl);
-+      /* Not enough args.
-+	 Determine minimum number of arguments required.  */
-+      int min_expected_num = 0;
-+      bool at_least_p = false;
-+      tree iter = typelist;
-+      while (true)
-+	{
-+	  if (!iter)
-+	    {
-+	      /* Variadic arguments; stop iterating.  */
-+	      at_least_p = true;
-+	      break;
-+	    }
-+	  if (iter == void_list_node)
-+	    /* End of arguments; stop iterating.  */
-+	    break;
-+	  ++min_expected_num;
-+	  iter = TREE_CHAIN (iter);
-+	}
-+      auto_diagnostic_group d;
-+      int actual_num = vec_safe_length (values);
-+      error_at (loc,
-+		at_least_p
-+		? G_("too few arguments to function %qE; expected at least %i, have %i")
-+		: G_("too few arguments to function %qE; expected %i, have %i"),
-+		function, min_expected_num, actual_num);
-+      inform_declaration (fundecl, function);
-       return -1;
-     }
- 
-@@ -4448,10 +4502,11 @@ convert_arguments (location_t loc, vec<location_t> arg_loc, tree fntype,
-       for (tree t = builtin_typetail; t; t = TREE_CHAIN (t))
- 	++nargs;
- 
-+      auto_diagnostic_group d;
-       if (warning_at (loc, OPT_Wbuiltin_declaration_mismatch,
- 		      "too few arguments to built-in function %qE "
- 		      "expecting %u", function, nargs - 1))
--	inform_declaration (fundecl);
-+	inform_declaration (fundecl, function);
-     }
- 
-   return error_args ? -1 : (int) parmnum;
-diff --git a/gcc/cp/typeck.cc b/gcc/cp/typeck.cc
-index 3e0d71102abd..a8580eddd397 100644
---- a/gcc/cp/typeck.cc
-+++ b/gcc/cp/typeck.cc
-@@ -59,7 +59,7 @@ static tree get_delta_difference (tree, tree, bool, bool, tsubst_flags_t);
- static void casts_away_constness_r (tree *, tree *, tsubst_flags_t);
- static bool casts_away_constness (tree, tree, tsubst_flags_t);
- static bool maybe_warn_about_returning_address_of_local (tree, location_t = UNKNOWN_LOCATION);
--static void error_args_num (location_t, tree, bool);
-+static void error_args_num (location_t, tree, int, int, bool);
- static int convert_arguments (tree, vec<tree, va_gc> **, tree, int,
-                               tsubst_flags_t);
- static bool is_std_move_p (tree);
-@@ -4535,11 +4535,19 @@ cp_build_function_call_vec (tree function, vec<tree, va_gc> **params,
- }
- \f
- /* Subroutine of convert_arguments.
--   Print an error message about a wrong number of arguments.  */
-+   Print an error message about a wrong number of arguments.
-+   If AT_LEAST_P is true, then EXPECTED_NUM is the minimum number
-+   of expected arguments, otherwise EXPECTED_NUM is the exact number
-+   of expected arguments.
-+   ACTUAL_NUM is the actual number of arguments that were explicitly
-+   passed at the callsite (i.e. not counting default arguments).  */
- 
- static void
--error_args_num (location_t loc, tree fndecl, bool too_many_p)
-+error_args_num (location_t loc, tree fndecl, int expected_num, int actual_num,
-+		bool at_least_p)
- {
-+  gcc_assert (expected_num != actual_num);
-+  const bool too_many_p = actual_num > expected_num;
-   if (fndecl)
-     {
-       auto_diagnostic_group d;
-@@ -4550,22 +4558,28 @@ error_args_num (location_t loc, tree fndecl, bool too_many_p)
- 		  == DECL_NAME (TYPE_NAME (DECL_CONTEXT (fndecl)))))
- 	    error_at (loc,
- 		      too_many_p
--		      ? G_("too many arguments to constructor %q#D")
--		      : G_("too few arguments to constructor %q#D"),
--		      fndecl);
-+		      ? G_("too many arguments to constructor %q#D; expected %i, have %i")
-+		      : (at_least_p
-+			 ? G_("too few arguments to constructor %q#D; expected at least %i, have %i")
-+			 : G_("too few arguments to constructor %q#D; expected %i, have %i")),
-+		      fndecl, expected_num, actual_num);
- 	  else
- 	    error_at (loc,
- 		      too_many_p
--		      ? G_("too many arguments to member function %q#D")
--		      : G_("too few arguments to member function %q#D"),
--		      fndecl);
-+		      ? G_("too many arguments to member function %q#D; expected %i, have %i")
-+		      : (at_least_p
-+			 ? G_("too few arguments to member function %q#D; expected at least %i, have %i")
-+			 : G_("too few arguments to member function %q#D; expected %i, have %i")),
-+		      fndecl, expected_num, actual_num);
- 	}
-       else
- 	error_at (loc,
- 		  too_many_p
--		  ? G_("too many arguments to function %q#D")
--		  : G_("too few arguments to function %q#D"),
--		  fndecl);
-+		  ? G_("too many arguments to function %q#D; expected %i, have %i")
-+		  : (at_least_p
-+		     ? G_("too few arguments to function %q#D; expected at least %i, have %i")
-+		     : G_("too few arguments to function %q#D; expected %i, have %i")),
-+		  fndecl, expected_num, actual_num);
-       if (!DECL_IS_UNDECLARED_BUILTIN (fndecl))
- 	inform (DECL_SOURCE_LOCATION (fndecl), "declared here");
-     }
-@@ -4574,12 +4588,19 @@ error_args_num (location_t loc, tree fndecl, bool too_many_p)
-       if (c_dialect_objc ()  &&  objc_message_selector ())
- 	error_at (loc,
- 		  too_many_p
--		  ? G_("too many arguments to method %q#D")
--		  : G_("too few arguments to method %q#D"),
--		  objc_message_selector ());
-+		  ? G_("too many arguments to method %q#D; expected %i, have %i")
-+		  : (at_least_p
-+		     ? G_("too few arguments to method %q#D; expected at least %i, have %i")
-+		     : G_("too few arguments to method %q#D; expected %i, have %i")),
-+		  objc_message_selector (), expected_num, actual_num);
-       else
--	error_at (loc, too_many_p ? G_("too many arguments to function")
--		                  : G_("too few arguments to function"));
-+	error_at (loc,
-+		  too_many_p
-+		  ? G_("too many arguments to function; expected %i, have %i")
-+		  : (at_least_p
-+		     ? G_("too few arguments to function; expected at least %i, have %i")
-+		     : G_("too few arguments to function; expected %i, have %i")),
-+		  expected_num, actual_num);
-     }
- }
- 
-@@ -4609,9 +4630,11 @@ convert_arguments (tree typelist, vec<tree, va_gc> **values, tree fndecl,
-   /* Argument passing is always copy-initialization.  */
-   flags |= LOOKUP_ONLYCONVERTING;
- 
--  for (i = 0, typetail = typelist;
--       i < vec_safe_length (*values);
--       i++)
-+  /* Preserve actual number of arguments passed (without counting default
-+     args), in case we need to complain about too many/few.  */
-+  const unsigned actual_num = vec_safe_length (*values);
-+
-+  for (i = 0, typetail = typelist; i < actual_num; i++)
-     {
-       tree type = typetail ? TREE_VALUE (typetail) : 0;
-       tree val = (**values)[i];
-@@ -4623,7 +4646,10 @@ convert_arguments (tree typelist, vec<tree, va_gc> **values, tree fndecl,
- 	{
-           if (complain & tf_error)
-             {
--	      error_args_num (input_location, fndecl, /*too_many_p=*/true);
-+	      /* Too many args.  */
-+	      error_args_num (input_location, fndecl,
-+			      /*expected_num=*/i, actual_num,
-+			      /*at_least_p=*/false);
-               return i;
-             }
-           else
-@@ -4745,7 +4771,41 @@ convert_arguments (tree typelist, vec<tree, va_gc> **values, tree fndecl,
-       if (typetail && typetail != void_list_node)
- 	{
- 	  if (complain & tf_error)
--	    error_args_num (input_location, fndecl, /*too_many_p=*/false);
-+	    {
-+	      /* Not enough args.
-+		 Determine minimum number of arguments required.  */
-+	      int min_expected_num = 0;
-+	      bool at_least_p = false;
-+	      tree iter = typelist;
-+	      while (true)
-+		{
-+		  if (!iter)
-+		    {
-+		      /* Variadic arguments; stop iterating.  */
-+		      at_least_p = true;
-+		      break;
-+		    }
-+		  if (iter == void_list_node)
-+		    /* End of arguments; stop iterating.  */
-+		    break;
-+		  if (fndecl && TREE_PURPOSE (iter))
-+		    {
-+		      /* Found a default argument; skip this one when
-+			 counting minimum required, but there might
-+			 be non-default arguments left to count:
-+			 after DR777, with explicit template args we can
-+			 end up with a default argument followed by
-+			 no default argument.  */
-+		      at_least_p = true;
-+		      iter = TREE_CHAIN (iter);
-+		      continue;
-+		    }
-+		  ++min_expected_num;
-+		  iter = TREE_CHAIN (iter);
-+		}
-+	      error_args_num (input_location, fndecl,
-+			      min_expected_num, actual_num, at_least_p);
-+	    }
- 	  return -1;
- 	}
-     }
-diff --git a/gcc/testsuite/c-c++-common/too-few-arguments.c b/gcc/testsuite/c-c++-common/too-few-arguments.c
-new file mode 100644
-index 000000000000..633dccfeaf24
---- /dev/null
-+++ b/gcc/testsuite/c-c++-common/too-few-arguments.c
-@@ -0,0 +1,38 @@
-+extern void fn_a (void);
-+extern void fn_b (int); /* { dg-message "declared here" } */
-+extern void fn_c (int, int); /* { dg-message "declared here" } */
-+#ifdef __cplusplus
-+extern void fn_d (int, int=42); /* { dg-message "declared here" "" { target c++ } } */
-+extern void fn_e (int, int=42, int=1066); /* { dg-message "declared here" "" { target c++ } } */
-+#endif
-+extern void fn_f (const char *, ...); /* { dg-message "declared here" } */
-+
-+void test_known_fn (void)
-+{
-+  fn_a ();
-+  fn_b ();  /* { dg-error "too few arguments to function '\[^\n\r\]*'; expected 1, have 0" } */
-+  fn_c (42);/* { dg-error "too few arguments to function '\[^\n\r\]*'; expected 2, have 1" } */
-+#ifdef __cplusplus
-+  fn_d ();  /* { dg-error "too few arguments to function '\[^\n\r\]*'; expected at least 1, have 0" "" { target c++ } } */
-+  fn_e ();  /* { dg-error "too few arguments to function '\[^\n\r\]*'; expected at least 1, have 0" "" { target c++ } } */
-+#endif
-+  fn_f ();  /* { dg-error "too few arguments to function '\[^\n\r\]*'; expected at least 1, have 0" } */
-+}
-+
-+struct foo
-+{
-+  void (*callback_a) (void);
-+  void (*callback_b) (int); /* { dg-message "declared here" "" { target c } } */
-+  void (*callback_c) (int, int); /* { dg-message "declared here" "" { target c } } */
-+};
-+
-+void test_callback (struct foo *f)
-+{
-+  f->callback_a ();
-+  
-+  f->callback_b (); /* { dg-error "too few arguments to function 'f->callback_b'; expected 1, have 0" "" { target c } } */
-+  /* { dg-error "too few arguments to function; expected 1, have 0" "" { target c++ } .-1 } */
-+
-+  f->callback_c (42); /* { dg-error "too few arguments to function 'f->callback_c'; expected 2, have 1" "" { target c } } */
-+  /* { dg-error "too few arguments to function; expected 2, have 1" "" { target c++ } .-1 } */
-+}
-diff --git a/gcc/testsuite/c-c++-common/too-many-arguments.c b/gcc/testsuite/c-c++-common/too-many-arguments.c
-new file mode 100644
-index 000000000000..7f9f8d4870bf
---- /dev/null
-+++ b/gcc/testsuite/c-c++-common/too-many-arguments.c
-@@ -0,0 +1,96 @@
-+/* For C, verify that the first excess param is underlined.
-+   For C++ the calls location covers all the params, so we
-+   can't underline individual params.  */
-+/* { dg-additional-options "-fdiagnostics-show-caret" { target c } } */
-+
-+extern void fn_a (); /* { dg-message "declared here" } */
-+extern void fn_b (void); /* { dg-message "declared here" } */
-+extern void fn_c (int); /* { dg-message "declared here" } */
-+#ifdef __cplusplus
-+extern void fn_d (int, int=42); /* { dg-message "declared here" "" { target c++ } } */
-+#endif
-+
-+void test_known_fn (void)
-+{
-+  fn_a (42); /* { dg-error "too many arguments to function 'fn_a'; expected 0, have 1" "" { target c } } */
-+  /* { dg-error "too many arguments to function 'void fn_a\\(\\)'; expected 0, have 1" "" { target c++ } .-1 } */
-+  /* { dg-begin-multiline-output "" }
-+   fn_a (42);
-+   ^~~~  ~~
-+     { dg-end-multiline-output "" { target c } } */
-+  /* { dg-begin-multiline-output "" }
-+ extern void fn_a ();
-+             ^~~~
-+     { dg-end-multiline-output "" { target c } } */
-+
-+  fn_b (1776); /* { dg-error "too many arguments to function 'fn_b'; expected 0, have 1" "" { target c } } */
-+  /* { dg-error "too many arguments to function 'void fn_b\\(\\)'; expected 0, have 1" "" { target c++ } .-1 } */
-+  /* { dg-begin-multiline-output "" }
-+   fn_b (1776);
-+   ^~~~  ~~~~
-+   { dg-end-multiline-output "" { target c } } */
-+  /* { dg-begin-multiline-output "" }
-+ extern void fn_b (void);
-+             ^~~~
-+     { dg-end-multiline-output "" { target c } } */
-+
-+  fn_c (1066, 1649);  /* { dg-error "too many arguments to function 'fn_c'; expected 1, have 2" "" { target c } } */
-+  /* { dg-error "too many arguments to function 'void fn_c\\(int\\)'; expected 1, have 2" "" { target c++ } .-1 } */
-+  /* { dg-begin-multiline-output "" }
-+   fn_c (1066, 1649);
-+   ^~~~        ~~~~
-+   { dg-end-multiline-output "" { target c } } */
-+  /* { dg-begin-multiline-output "" }
-+ extern void fn_c (int);
-+             ^~~~
-+     { dg-end-multiline-output "" { target c } } */
-+
-+#ifdef __cplusplus
-+  fn_d (1066);
-+  fn_d (1066, 1649);
-+  fn_d (1066, 1649, 1776); /* { dg-error "too many arguments to function '\[^\n\r\]*'; expected 2, have 3" "" { target c++ } } */
-+#endif
-+}
-+
-+struct foo
-+{
-+  void (*callback_a)(); /* { dg-message "declared here" "" { target c } } */
-+  void (*callback_b)(void); /* { dg-message "declared here" "" { target c } } */
-+  void (*callback_c)(int); /* { dg-message "declared here" "" { target c } } */
-+};
-+
-+void test_callback (struct foo *f)
-+{
-+  f->callback_a (42); /* { dg-error "too many arguments to function 'f->callback_a'; expected 0, have 1" "" { target c } } */
-+  /* { dg-error "too many arguments to function; expected 0, have 1" "" { target c++ } .-1 } */
-+  /* { dg-begin-multiline-output "" }
-+   f->callback_a (42);
-+   ^              ~~
-+     { dg-end-multiline-output "" { target c } } */
-+  /* { dg-begin-multiline-output "" }
-+   void (*callback_a)();
-+          ^~~~~~~~~~
-+     { dg-end-multiline-output "" { target c } } */
-+  
-+  f->callback_b (1776); /* { dg-error "too many arguments to function 'f->callback_b'; expected 0, have 1" "" { target c } } */
-+  /* { dg-error "too many arguments to function; expected 0, have 1" "" { target c++ } .-1 } */
-+  /* { dg-begin-multiline-output "" }
-+   f->callback_b (1776);
-+   ^              ~~~~
-+     { dg-end-multiline-output "" { target c } } */
-+  /* { dg-begin-multiline-output "" }
-+   void (*callback_b)(void);
-+          ^~~~~~~~~~
-+     { dg-end-multiline-output "" { target c } } */
-+
-+  f->callback_c (1066, 1649); /* { dg-error "too many arguments to function 'f->callback_c'; expected 1, have 2" "" { target c } } */
-+  /* { dg-error "too many arguments to function; expected 1, have 2" "" { target c++ } .-1 } */
-+  /* { dg-begin-multiline-output "" }
-+   f->callback_c (1066, 1649);
-+   ^                    ~~~~
-+     { dg-end-multiline-output "" { target c } } */
-+  /* { dg-begin-multiline-output "" }
-+   void (*callback_c)(int);
-+          ^~~~~~~~~~
-+     { dg-end-multiline-output "" { target c } } */
-+}
-diff --git a/gcc/testsuite/g++.dg/cpp0x/variadic169.C b/gcc/testsuite/g++.dg/cpp0x/variadic169.C
-index 6858973cd2eb..460bb3b8a193 100644
---- a/gcc/testsuite/g++.dg/cpp0x/variadic169.C
-+++ b/gcc/testsuite/g++.dg/cpp0x/variadic169.C
-@@ -5,5 +5,5 @@ template<typename ...T> void f(int n = 0, T ...t);
- 
- int main()
- {
--  f<int>();			// { dg-error "too few arguments" }
-+  f<int>();			// { dg-error "too few arguments to function '\[^\n\r\]*'; expected at least 1, have 0" }
- }
-diff --git a/gcc/testsuite/g++.dg/modules/macloc-1_c.C b/gcc/testsuite/g++.dg/modules/macloc-1_c.C
-index 5865a34687e7..3f980c213814 100644
---- a/gcc/testsuite/g++.dg/modules/macloc-1_c.C
-+++ b/gcc/testsuite/g++.dg/modules/macloc-1_c.C
-@@ -8,6 +8,6 @@ void gru ()
-   you (1);
- }
- 
--// { dg-regexp "\[^\n]*macloc-1_c.C:7:6: error: too many arguments to function 'int me@agnes\\(\\)'\nIn module agnes, imported at \[^\n]*macloc-1_b.C:8,\nof module edith, imported at \[^\n]*macloc-1_c.C:3:\n\[^\n]*macloc-1_a.C:11:12: note: declared here\n\[^\n]*macloc-1_a.C:8:20: note: in definition of macro 'BOB'\n" }
-+// { dg-regexp "\[^\n]*macloc-1_c.C:7:6: error: too many arguments to function 'int me@agnes\\(\\)'; expected 0, have 1\nIn module agnes, imported at \[^\n]*macloc-1_b.C:8,\nof module edith, imported at \[^\n]*macloc-1_c.C:3:\n\[^\n]*macloc-1_a.C:11:12: note: declared here\n\[^\n]*macloc-1_a.C:8:20: note: in definition of macro 'BOB'\n" }
- 
--// { dg-regexp "\[^\n]*macloc-1_c.C:8:7: error: too many arguments to function 'int you@agnes\\(\\)'\nIn module agnes, imported at \[^\n]*macloc-1_b.C:8,\nof module edith, imported at \[^\n]*macloc-1_c.C:3:\n\[^\n]*macloc-1_a.C:12:14: note: declared here\n\[^\n]*macloc-1_a.C:9:22: note: in definition of macro 'KEVIN'\n" }
-+// { dg-regexp "\[^\n]*macloc-1_c.C:8:7: error: too many arguments to function 'int you@agnes\\(\\)'; expected 0, have 1\nIn module agnes, imported at \[^\n]*macloc-1_b.C:8,\nof module edith, imported at \[^\n]*macloc-1_c.C:3:\n\[^\n]*macloc-1_a.C:12:14: note: declared here\n\[^\n]*macloc-1_a.C:9:22: note: in definition of macro 'KEVIN'\n" }
-diff --git a/gcc/testsuite/g++.dg/modules/macloc-1_d.C b/gcc/testsuite/g++.dg/modules/macloc-1_d.C
-index 282a31c4a2d1..56c001fc3f83 100644
---- a/gcc/testsuite/g++.dg/modules/macloc-1_d.C
-+++ b/gcc/testsuite/g++.dg/modules/macloc-1_d.C
-@@ -9,5 +9,5 @@ void margo ()
-   gru (2);
- }
- 
--// { dg-regexp "\[^\n]*macloc-1_d.C:8:6: error: too many arguments to function 'int me@agnes\\(\\)'\nIn module agnes, imported at \[^\n]*macloc-1_d.C:4:\n\[^\n]*macloc-1_a.C:11:12: note: declared here\n\[^\n]*macloc-1_a.C:8:20: note: in definition of macro 'BOB'\n" }
--// { dg-regexp "\[^\n]*macloc-1_d.C:9:7: error: too many arguments to function 'void gru@edith\\(\\)'\nIn module edith, imported at \[^\n]*macloc-1_d.C:3:\n\[^\n]*macloc-1_b.C:10:20: note: declared here\n\[^\n]*macloc-1_b.C:6:19: note: in definition of macro 'STUART'\n" }
-+// { dg-regexp "\[^\n]*macloc-1_d.C:8:6: error: too many arguments to function 'int me@agnes\\(\\)'; expected 0, have 1\nIn module agnes, imported at \[^\n]*macloc-1_d.C:4:\n\[^\n]*macloc-1_a.C:11:12: note: declared here\n\[^\n]*macloc-1_a.C:8:20: note: in definition of macro 'BOB'\n" }
-+// { dg-regexp "\[^\n]*macloc-1_d.C:9:7: error: too many arguments to function 'void gru@edith\\(\\)'; expected 0, have 1\nIn module edith, imported at \[^\n]*macloc-1_d.C:3:\n\[^\n]*macloc-1_b.C:10:20: note: declared here\n\[^\n]*macloc-1_b.C:6:19: note: in definition of macro 'STUART'\n" }
-
-base-commit: 65286465b94cba6ee3d59edbc771bef0088ac46e
--- 
-2.48.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 7b6d0a6..3b41aa8 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 37	????
 
+	- 77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
 	- 78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch
 	- 79_all_PR32491-fix-binutils-arm-check.patch
 	+ 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-13  0:20 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-13  0:20 UTC (permalink / raw
  To: gentoo-commits
commit:     1082c8487ab7217c389fff3d43bc7de9345ef0d1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan 13 00:20:04 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan 13 00:20:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=1082c848
15.0.0: cut patchset 37
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 3b41aa8..f3ab09a 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-37	????
+37	13 January 2025
 
 	- 77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
 	- 78_all_PR118032-Revert-gimple-Add-limit-after-which-slower-switchlow.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-13  3:20 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-13  3:20 UTC (permalink / raw
  To: gentoo-commits
commit:     9990b777a4ae73b77ef376ee7aebfd0ac8523754
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan 13 03:20:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan 13 03:20:09 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=9990b777
15.0.0: add ifcombine patch
Bug: https://gcc.gnu.org/PR118409
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/82_all_PR118409-ifcombine.patch | 146 ++++++++++++++++++++++++++
 15.0.0/gentoo/README.history                  |   4 +
 2 files changed, 150 insertions(+)
diff --git a/15.0.0/gentoo/82_all_PR118409-ifcombine.patch b/15.0.0/gentoo/82_all_PR118409-ifcombine.patch
new file mode 100644
index 0000000..e599f21
--- /dev/null
+++ b/15.0.0/gentoo/82_all_PR118409-ifcombine.patch
@@ -0,0 +1,146 @@
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=118409#c26
+
+[ifcombine] propagate signbit mask to XOR right-hand operand
+
+From: Alexandre Oliva <oliva@adacore.com>
+
+If a single-bit bitfield takes up the sign bit of a storage unit,
+comparing the corresponding bitfield between two objects loads the
+storage units, XORs them, converts the result to signed char, and
+compares it with zero: ((signed char)(a.<byte> ^ c.<byte>) >= 0).
+
+fold_truth_andor_for_ifcombine recognizes the compare with zero as a
+sign bit test, then it decomposes the XOR into an equality test.
+
+The problem is that, after this decomposition, that figures out the
+width of the accessed fields, we apply the sign bit mask to the
+left-hand operand of the compare, but we failed to also apply it to
+the right-hand operand when both were taken from the same XOR.
+
+This patch fixes that.
+
+
+for  gcc/ChangeLog
+
+	PR tree-optimization/118409
+	* gimple-fold.cc (fold_truth_andor_for_ifcombine): Apply the
+	signbit mask to the right-hand XOR operand too.
+
+for  gcc/testsuite/ChangeLog
+
+	PR tree-optimization/118409
+	* gcc.dg/field-merge-20.c: New.
+---
+ gcc/gimple-fold.cc                    |   20 ++++++++++
+ gcc/testsuite/gcc.dg/field-merge-20.c |   64 +++++++++++++++++++++++++++++++++
+ 2 files changed, 84 insertions(+)
+ create mode 100644 gcc/testsuite/gcc.dg/field-merge-20.c
+
+diff --git a/gcc/gimple-fold.cc b/gcc/gimple-fold.cc
+index a3987c4590ae6..93ed8b3abb056 100644
+--- a/gcc/gimple-fold.cc
++++ b/gcc/gimple-fold.cc
+@@ -8270,6 +8270,16 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+ 	ll_and_mask = sign;
+       else
+ 	ll_and_mask &= sign;
++      if (l_xor)
++	{
++	  if (!lr_and_mask.get_precision ())
++	    lr_and_mask = sign;
++	  else
++	    lr_and_mask &= sign;
++	  if (l_const.get_precision ())
++	    l_const &= wide_int::from (lr_and_mask,
++				       l_const.get_precision (), UNSIGNED);
++	}
+     }
+ 
+   if (rsignbit)
+@@ -8279,6 +8289,16 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+ 	rl_and_mask = sign;
+       else
+ 	rl_and_mask &= sign;
++      if (r_xor)
++	{
++	  if (!rr_and_mask.get_precision ())
++	    rr_and_mask = sign;
++	  else
++	    rr_and_mask &= sign;
++	  if (r_const.get_precision ())
++	    r_const &= wide_int::from (rr_and_mask,
++				       r_const.get_precision (), UNSIGNED);
++	}
+     }
+ 
+   /* If either comparison code is not correct for our logical operation,
+diff --git a/gcc/testsuite/gcc.dg/field-merge-20.c b/gcc/testsuite/gcc.dg/field-merge-20.c
+new file mode 100644
+index 0000000000000..44ac7fae50dc5
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/field-merge-20.c
+@@ -0,0 +1,64 @@
++/* { dg-do run } */
++/* { dg-options "-O1" } */
++
++/* tree-optimization/118409 */
++
++/* Check that tests involving a sign bit of a storage unit are handled
++   correctly.  The compares are turned into xor tests by earlier passes, and
++   ifcombine has to propagate the sign bit mask to the right hand of the
++   compare extracted from the xor, otherwise we'll retain unwanted bits for the
++   compare.  */
++
++typedef struct {
++    int p : __CHAR_BIT__;
++    int d : 1;
++    int b : __CHAR_BIT__ - 2;
++    int e : 1;
++} g;
++
++g a = {.d = 1, .e = 1}, c = {.b = 1, .d = 1, .e = 1};
++
++__attribute__((noipa))
++int f1 ()
++{
++  if (a.d == c.d
++      && a.e == c.e)
++    return 0;
++  return -1;
++}
++
++__attribute__((noipa))
++int f2 ()
++{
++  if (a.d != c.d
++      || a.e != c.e)
++    return -1;
++  return 0;
++}
++
++__attribute__((noipa))
++int f3 ()
++{
++  if (c.d == a.d
++      && c.e == a.e)
++    return 0;
++  return -1;
++}
++
++__attribute__((noipa))
++int f4 ()
++{
++  if (c.d != a.d
++      || c.e != a.e)
++    return -1;
++  return 0;
++}
++
++int main() {
++  if (f1 () < 0
++      || f2 () < 0
++      || f3 () < 0
++      || f4 () < 0)
++    __builtin_abort();
++  return 0;
++}
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index f3ab09a..1f53f35 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+38	????
+
+	+ 82_all_PR118409-ifcombine.patch
+
 37	13 January 2025
 
 	- 77_all_PR118112-c-c-UX-improvements-to-too-few-many-arguments-errors.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-13  3:23 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-13  3:23 UTC (permalink / raw
  To: gentoo-commits
commit:     9034a6d5fcf3a2ead9735466c906830d472a2f9c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan 13 03:23:31 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan 13 03:23:38 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=9034a6d5
15.0.0: add parallel build patch for D
Thank you Arsen!
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-d-give-dependency-files-better-filenames.patch | 54 ++++++++++++++++++++++
 15.0.0/gentoo/README.history                       |  1 +
 2 files changed, 55 insertions(+)
diff --git a/15.0.0/gentoo/83_all-gcc-d-give-dependency-files-better-filenames.patch b/15.0.0/gentoo/83_all-gcc-d-give-dependency-files-better-filenames.patch
new file mode 100644
index 0000000..98156e4
--- /dev/null
+++ b/15.0.0/gentoo/83_all-gcc-d-give-dependency-files-better-filenames.patch
@@ -0,0 +1,54 @@
+https://inbox.sourceware.org/gcc-patches/20250112153348.1578402-1-arsen@aarsen.me/
+
+From 327b1b3834b4e3c80b209a35a73b063a0f9bfd75 Mon Sep 17 00:00:00 2001
+Message-ID: <327b1b3834b4e3c80b209a35a73b063a0f9bfd75.1736738577.git.sam@gentoo.org>
+From: =?UTF-8?q?Arsen=20Arsenovi=C4=87?= <arsen@aarsen.me>
+Date: Sun, 12 Jan 2025 16:16:58 +0100
+Subject: [PATCH] gcc/d: give dependency files better filenames
+
+Currently, the dependency files for root-file.o and common-file.o were
+both d/.deps/file.Po, which would cause parallel builds to fail
+sometimes with:
+
+  make[3]: Leaving directory '/var/tmp/portage/sys-devel/gcc-14.1.1_p20240511/work/build/gcc'
+  make[3]: Entering directory '/var/tmp/portage/sys-devel/gcc-14.1.1_p20240511/work/build/gcc'
+  mv: cannot stat 'd/.deps/file.TPo': No such file or directory
+  make[3]: *** [/var/tmp/portage/sys-devel/gcc-14.1.1_p20240511/work/gcc-14-20240511/gcc/d/Make-lang.in:421: d/root-file.o] Error 1 shuffle=131581365
+
+Also, this means that dependencies of one of root-file or common-file
+are missing when developing.  After this patch, those two files get
+assigned dependency files d/.deps/d-root-file.o.Po and
+d/.deps/d-common-file.o.Po respectively.
+
+There are other files with similar conflicts (mangle-package.o,
+visitor-package.o for instance).
+
+gcc/d/ChangeLog:
+
+* Make-lang.in: Assign dependency-tracking files better
+	filenames.
+---
+ gcc/d/Make-lang.in | 5 +++--
+ 1 file changed, 3 insertions(+), 2 deletions(-)
+
+diff --git a/gcc/d/Make-lang.in b/gcc/d/Make-lang.in
+index f28761e4b370..25e2b0bbfe94 100644
+--- a/gcc/d/Make-lang.in
++++ b/gcc/d/Make-lang.in
+@@ -65,8 +65,9 @@ ALL_DFLAGS = $(DFLAGS-$@) $(GDCFLAGS) -fversion=IN_GCC $(CHECKING_DFLAGS) \
+ 	$(WARN_DFLAGS)
+ 
+ DCOMPILE.base = $(GDC) -c $(ALL_DFLAGS) -o $@
+-DCOMPILE = $(DCOMPILE.base) -MT $@ -MMD -MP -MF $(@D)/$(DEPDIR)/$(*F).TPo
+-DPOSTCOMPILE = @mv $(@D)/$(DEPDIR)/$(*F).TPo $(@D)/$(DEPDIR)/$(*F).Po
++DEPFILE = $(subst /,-,$@)
++DCOMPILE = $(DCOMPILE.base) -MT $@ -MMD -MP -MF $(@D)/$(DEPDIR)/$(DEPFILE).TPo
++DPOSTCOMPILE = @mv $(@D)/$(DEPDIR)/$(DEPFILE).TPo $(@D)/$(DEPDIR)/$(DEPFILE).Po
+ DLINKER = $(GDC) $(NO_PIE_FLAG) -lstdc++
+ 
+ # Like LINKER, but use a mutex for serializing front end links.
+
+base-commit: 0e05b793fba2a9bea9f0fbb1f068679f5dadf514
+-- 
+2.48.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 1f53f35..58edd02 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 38	????
 
 	+ 82_all_PR118409-ifcombine.patch
+	+ 83_all-gcc-d-give-dependency-files-better-filenames.patch
 
 37	13 January 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-13  3:40 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-13  3:40 UTC (permalink / raw
  To: gentoo-commits
commit:     a4f03b7491ffd0fdab5df8d89c96ea3ba8b17838
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan 13 03:39:58 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan 13 03:39:58 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=a4f03b74
15.0.0: add ML link to ifcombine patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/82_all_PR118409-ifcombine.patch | 24 ++++++++++++++++--------
 1 file changed, 16 insertions(+), 8 deletions(-)
diff --git a/15.0.0/gentoo/82_all_PR118409-ifcombine.patch b/15.0.0/gentoo/82_all_PR118409-ifcombine.patch
index e599f21..6362cd1 100644
--- a/15.0.0/gentoo/82_all_PR118409-ifcombine.patch
+++ b/15.0.0/gentoo/82_all_PR118409-ifcombine.patch
@@ -1,8 +1,10 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=118409#c26
-
-[ifcombine] propagate signbit mask to XOR right-hand operand
+https://inbox.sourceware.org/gcc-patches/ored17gz9x.fsf@lxoliva.fsfla.org/
 
+From bfb791ad941348a0bb854b770f2294424528bc40 Mon Sep 17 00:00:00 2001
+Message-ID: <bfb791ad941348a0bb854b770f2294424528bc40.1736739564.git.sam@gentoo.org>
 From: Alexandre Oliva <oliva@adacore.com>
+Date: Mon, 13 Jan 2025 00:37:14 -0300
+Subject: [PATCH] propagate signbit mask to XOR right-hand operand
 
 If a single-bit bitfield takes up the sign bit of a storage unit,
 comparing the corresponding bitfield between two objects loads the
@@ -19,6 +21,7 @@ the right-hand operand when both were taken from the same XOR.
 
 This patch fixes that.
 
+Regstrapped on x86_64-linux-gnu.  Ok to install?
 
 for  gcc/ChangeLog
 
@@ -28,16 +31,16 @@ for  gcc/ChangeLog
 
 for  gcc/testsuite/ChangeLog
 
-	PR tree-optimization/118409
+PR tree-optimization/118409
 	* gcc.dg/field-merge-20.c: New.
 ---
- gcc/gimple-fold.cc                    |   20 ++++++++++
- gcc/testsuite/gcc.dg/field-merge-20.c |   64 +++++++++++++++++++++++++++++++++
+ gcc/gimple-fold.cc                    | 20 +++++++++
+ gcc/testsuite/gcc.dg/field-merge-20.c | 64 +++++++++++++++++++++++++++
  2 files changed, 84 insertions(+)
  create mode 100644 gcc/testsuite/gcc.dg/field-merge-20.c
 
 diff --git a/gcc/gimple-fold.cc b/gcc/gimple-fold.cc
-index a3987c4590ae6..93ed8b3abb056 100644
+index a3987c4590ae..93ed8b3abb05 100644
 --- a/gcc/gimple-fold.cc
 +++ b/gcc/gimple-fold.cc
 @@ -8270,6 +8270,16 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
@@ -76,7 +79,7 @@ index a3987c4590ae6..93ed8b3abb056 100644
    /* If either comparison code is not correct for our logical operation,
 diff --git a/gcc/testsuite/gcc.dg/field-merge-20.c b/gcc/testsuite/gcc.dg/field-merge-20.c
 new file mode 100644
-index 0000000000000..44ac7fae50dc5
+index 000000000000..44ac7fae50dc
 --- /dev/null
 +++ b/gcc/testsuite/gcc.dg/field-merge-20.c
 @@ -0,0 +1,64 @@
@@ -144,3 +147,8 @@ index 0000000000000..44ac7fae50dc5
 +    __builtin_abort();
 +  return 0;
 +}
+
+base-commit: 0e05b793fba2a9bea9f0fbb1f068679f5dadf514
+-- 
+2.48.0
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-13  6:00 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-13  6:00 UTC (permalink / raw
  To: gentoo-commits
commit:     9ffb270464521895475f4e645b3df333d111c521
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan 13 06:00:10 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan 13 06:00:10 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=9ffb2704
15.0.0: cut patchset 38
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 58edd02..fdb33be 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-38	????
+38	13 January 2023
 
 	+ 82_all_PR118409-ifcombine.patch
 	+ 83_all-gcc-d-give-dependency-files-better-filenames.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-13 13:58 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-13 13:58 UTC (permalink / raw
  To: gentoo-commits
commit:     b8a7e53a40d7938319d7673deba04c43952f84d8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jan 13 13:58:49 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan 13 13:58:49 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b8a7e53a
15.0.0: drop upstream 82_all_PR118409-ifcombine.patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/82_all_PR118409-ifcombine.patch | 154 --------------------------
 15.0.0/gentoo/README.history                  |   4 +
 2 files changed, 4 insertions(+), 154 deletions(-)
diff --git a/15.0.0/gentoo/82_all_PR118409-ifcombine.patch b/15.0.0/gentoo/82_all_PR118409-ifcombine.patch
deleted file mode 100644
index 6362cd1..0000000
--- a/15.0.0/gentoo/82_all_PR118409-ifcombine.patch
+++ /dev/null
@@ -1,154 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/ored17gz9x.fsf@lxoliva.fsfla.org/
-
-From bfb791ad941348a0bb854b770f2294424528bc40 Mon Sep 17 00:00:00 2001
-Message-ID: <bfb791ad941348a0bb854b770f2294424528bc40.1736739564.git.sam@gentoo.org>
-From: Alexandre Oliva <oliva@adacore.com>
-Date: Mon, 13 Jan 2025 00:37:14 -0300
-Subject: [PATCH] propagate signbit mask to XOR right-hand operand
-
-If a single-bit bitfield takes up the sign bit of a storage unit,
-comparing the corresponding bitfield between two objects loads the
-storage units, XORs them, converts the result to signed char, and
-compares it with zero: ((signed char)(a.<byte> ^ c.<byte>) >= 0).
-
-fold_truth_andor_for_ifcombine recognizes the compare with zero as a
-sign bit test, then it decomposes the XOR into an equality test.
-
-The problem is that, after this decomposition, that figures out the
-width of the accessed fields, we apply the sign bit mask to the
-left-hand operand of the compare, but we failed to also apply it to
-the right-hand operand when both were taken from the same XOR.
-
-This patch fixes that.
-
-Regstrapped on x86_64-linux-gnu.  Ok to install?
-
-for  gcc/ChangeLog
-
-	PR tree-optimization/118409
-	* gimple-fold.cc (fold_truth_andor_for_ifcombine): Apply the
-	signbit mask to the right-hand XOR operand too.
-
-for  gcc/testsuite/ChangeLog
-
-PR tree-optimization/118409
-	* gcc.dg/field-merge-20.c: New.
----
- gcc/gimple-fold.cc                    | 20 +++++++++
- gcc/testsuite/gcc.dg/field-merge-20.c | 64 +++++++++++++++++++++++++++
- 2 files changed, 84 insertions(+)
- create mode 100644 gcc/testsuite/gcc.dg/field-merge-20.c
-
-diff --git a/gcc/gimple-fold.cc b/gcc/gimple-fold.cc
-index a3987c4590ae..93ed8b3abb05 100644
---- a/gcc/gimple-fold.cc
-+++ b/gcc/gimple-fold.cc
-@@ -8270,6 +8270,16 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
- 	ll_and_mask = sign;
-       else
- 	ll_and_mask &= sign;
-+      if (l_xor)
-+	{
-+	  if (!lr_and_mask.get_precision ())
-+	    lr_and_mask = sign;
-+	  else
-+	    lr_and_mask &= sign;
-+	  if (l_const.get_precision ())
-+	    l_const &= wide_int::from (lr_and_mask,
-+				       l_const.get_precision (), UNSIGNED);
-+	}
-     }
- 
-   if (rsignbit)
-@@ -8279,6 +8289,16 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
- 	rl_and_mask = sign;
-       else
- 	rl_and_mask &= sign;
-+      if (r_xor)
-+	{
-+	  if (!rr_and_mask.get_precision ())
-+	    rr_and_mask = sign;
-+	  else
-+	    rr_and_mask &= sign;
-+	  if (r_const.get_precision ())
-+	    r_const &= wide_int::from (rr_and_mask,
-+				       r_const.get_precision (), UNSIGNED);
-+	}
-     }
- 
-   /* If either comparison code is not correct for our logical operation,
-diff --git a/gcc/testsuite/gcc.dg/field-merge-20.c b/gcc/testsuite/gcc.dg/field-merge-20.c
-new file mode 100644
-index 000000000000..44ac7fae50dc
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/field-merge-20.c
-@@ -0,0 +1,64 @@
-+/* { dg-do run } */
-+/* { dg-options "-O1" } */
-+
-+/* tree-optimization/118409 */
-+
-+/* Check that tests involving a sign bit of a storage unit are handled
-+   correctly.  The compares are turned into xor tests by earlier passes, and
-+   ifcombine has to propagate the sign bit mask to the right hand of the
-+   compare extracted from the xor, otherwise we'll retain unwanted bits for the
-+   compare.  */
-+
-+typedef struct {
-+    int p : __CHAR_BIT__;
-+    int d : 1;
-+    int b : __CHAR_BIT__ - 2;
-+    int e : 1;
-+} g;
-+
-+g a = {.d = 1, .e = 1}, c = {.b = 1, .d = 1, .e = 1};
-+
-+__attribute__((noipa))
-+int f1 ()
-+{
-+  if (a.d == c.d
-+      && a.e == c.e)
-+    return 0;
-+  return -1;
-+}
-+
-+__attribute__((noipa))
-+int f2 ()
-+{
-+  if (a.d != c.d
-+      || a.e != c.e)
-+    return -1;
-+  return 0;
-+}
-+
-+__attribute__((noipa))
-+int f3 ()
-+{
-+  if (c.d == a.d
-+      && c.e == a.e)
-+    return 0;
-+  return -1;
-+}
-+
-+__attribute__((noipa))
-+int f4 ()
-+{
-+  if (c.d != a.d
-+      || c.e != a.e)
-+    return -1;
-+  return 0;
-+}
-+
-+int main() {
-+  if (f1 () < 0
-+      || f2 () < 0
-+      || f3 () < 0
-+      || f4 () < 0)
-+    __builtin_abort();
-+  return 0;
-+}
-
-base-commit: 0e05b793fba2a9bea9f0fbb1f068679f5dadf514
--- 
-2.48.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index fdb33be..2789ef2 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+39	????
+
+	- 82_all_PR118409-ifcombine.patch
+
 38	13 January 2023
 
 	+ 82_all_PR118409-ifcombine.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-14  8:40 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-14  8:40 UTC (permalink / raw
  To: gentoo-commits
commit:     5846888a3bfdec16452129958b6a678b378ac03f
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jan 14 08:39:36 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jan 14 08:39:42 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=5846888a
15.0.0: update 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
Hopefully fixes an issue I had with cross to cross-aarch64-unknown-linux-gnu
at least.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...358-Enable-automatic-linking-of-libatomic.patch | 3411 +++++++++++++++++++-
 15.0.0/gentoo/README.history                       |    1 +
 2 files changed, 3280 insertions(+), 132 deletions(-)
diff --git a/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch b/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
index d3424e7..b911f3e 100644
--- a/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
+++ b/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
@@ -1,12 +1,13 @@
-https://inbox.sourceware.org/gcc-patches/IA1PR12MB90310A559B28E87BF456C942CE072@IA1PR12MB9031.namprd12.prod.outlook.com/#t
+https://inbox.sourceware.org/gcc-patches/IA1PR12MB9031716BB477FC233DD9C60CCE1C2@IA1PR12MB9031.namprd12.prod.outlook.com/
 
 PR81358: Enable automatic linking of libatomic.
 
 ChangeLog:
 	PR driver/81358
-	* Makefile.def: Add dependencies so libatomic is built before target
-	libraries are configured.
+	* Makefile.def: Add dependencies for libatomic.
 	* Makefile.tpl: Export TARGET_CONFIGDIRS.
+	Add rules for no_atomic and dependency on libatomic for target
+	libraries.
 	* configure.ac: Add libatomic to bootstrap_target_libs.
 	* Makefile.in: Regenerate.
 	* configure: Regenerate.
@@ -21,6 +22,7 @@ gcc/ChangeLog:
 	* configure.ac: Define TARGET_PROVIDES_LIBATOMIC.
 	* configure: Regenerate.
 	* config.in: Regenerate.
+	* common.opt.urls: Regenerate.
 
 libatomic/ChangeLog:
 	PR driver/81358
@@ -34,53 +36,2918 @@ Signed-off-by: Prathamesh Kulkarni <prathameshk@nvidia.com>
 Co-authored-by: Matthew Malcolmson <mmalcolmson@nvidia.com>
 
 diff --git a/Makefile.def b/Makefile.def
-index 19954e7d731..90899fa28cf 100644
+index 19954e7d731..a765078ed41 100644
 --- a/Makefile.def
 +++ b/Makefile.def
-@@ -656,6 +656,26 @@ lang_env_dependencies = { module=libgcc; no_gcc=true; no_c=true; };
+@@ -648,13 +648,14 @@ dependencies = { module=all-m4; on=all-build-texinfo; };
+ // on libgcc and newlib/libgloss.
+ lang_env_dependencies = { module=libitm; cxx=true; };
+ lang_env_dependencies = { module=libffi; cxx=true; };
+-lang_env_dependencies = { module=newlib; no_c=true; };
+-lang_env_dependencies = { module=libgloss; no_c=true; };
+-lang_env_dependencies = { module=libgcc; no_gcc=true; no_c=true; };
++lang_env_dependencies = { module=newlib; no_c=true; no_atomic=true; };
++lang_env_dependencies = { module=libgloss; no_c=true; no_atomic=true; };
++lang_env_dependencies = { module=libgcc; no_gcc=true; no_c=true; no_atomic=true; };
+ // libiberty does not depend on newlib or libgloss because it must be
+ // built newlib on some targets (e.g. Cygwin).  It still needs
  // a dependency on libgcc for native targets to configure.
- lang_env_dependencies = { module=libiberty; no_c=true; };
- 
-+dependencies = { module=configure-target-libbacktrace; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libgloss; on=all-target-libatomic; };
-+dependencies = { module=configure-target-newlib; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libgomp; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libitm; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libstdc++v3; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libsanitizer; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libvtv; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libssp; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libquadmath; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libgfortran; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libffi; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libobjc; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libada; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libgm2; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libgo; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libgrust; on=all-target-libatomic; };
-+dependencies = { module=configure-target-libphobos; on=all-target-libatomic; };
-+dependencies = { module=configure-target-zlib; on=all-target-libatomic; };
+-lang_env_dependencies = { module=libiberty; no_c=true; };
++lang_env_dependencies = { module=libiberty; no_c=true; no_atomic=true; };
++lang_env_dependencies = { module=libatomic; no_atomic=true; };
+ 
+ dependencies = { module=configure-target-fastjar; on=configure-target-zlib; };
+ dependencies = { module=all-target-fastjar; on=all-target-zlib; };
+diff --git a/Makefile.in b/Makefile.in
+index 966d6045496..a7969d0614b 100644
+--- a/Makefile.in
++++ b/Makefile.in
+@@ -242,6 +242,7 @@ HOST_EXPORTS = \
+ 	GMPINC="$(HOST_GMPINC)"; export GMPINC; \
+ 	ISLLIBS="$(HOST_ISLLIBS)"; export ISLLIBS; \
+ 	ISLINC="$(HOST_ISLINC)"; export ISLINC; \
++	TARGET_CONFIGDIRS="$(TARGET_CONFIGDIRS)"; export TARGET_CONFIGDIRS; \
+ 	XGCC_FLAGS_FOR_TARGET="$(XGCC_FLAGS_FOR_TARGET)"; export XGCC_FLAGS_FOR_TARGET; \
+ @if gcc-bootstrap
+ 	$(RPATH_ENVVAR)=`echo "$(TARGET_LIB_PATH)$$$(RPATH_ENVVAR)" | sed 's,::*,:,g;s,^:*,,;s,:*$$,,'`; export $(RPATH_ENVVAR); \
+@@ -68878,51 +68879,3240 @@ configure-target-libgrust: maybe-all-target-libgcc
+ 
+ configure-target-libstdc++-v3: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
++configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
++configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
++configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
++configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
++configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
++configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
++configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
++configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
++configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
++configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
++configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
++configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
++configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
++configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
++configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-rda: maybe-all-stage1-target-libatomic
++configure-stage2-target-rda: maybe-all-stage2-target-libatomic
++configure-stage3-target-rda: maybe-all-stage3-target-libatomic
++configure-stage4-target-rda: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libada: maybe-all-stage1-target-libatomic
++configure-stage2-target-libada: maybe-all-stage2-target-libatomic
++configure-stage3-target-libada: maybe-all-stage3-target-libatomic
++configure-stage4-target-libada: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
++configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
++configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
++configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libsanitizer: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
++configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
++configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
++configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
++configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
++configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
++configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
++configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
++configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
++configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
++configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
++configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
++configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
++configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
++configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
++configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-rda: maybe-all-stage1-target-libatomic
++configure-stage2-target-rda: maybe-all-stage2-target-libatomic
++configure-stage3-target-rda: maybe-all-stage3-target-libatomic
++configure-stage4-target-rda: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libada: maybe-all-stage1-target-libatomic
++configure-stage2-target-libada: maybe-all-stage2-target-libatomic
++configure-stage3-target-libada: maybe-all-stage3-target-libatomic
++configure-stage4-target-libada: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
++configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
++configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
++configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libvtv: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
++configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
++configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
++configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
++configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
++configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
++configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
++configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
++configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
++configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
++configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
++configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
++configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
++configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
++configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
++configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-rda: maybe-all-stage1-target-libatomic
++configure-stage2-target-rda: maybe-all-stage2-target-libatomic
++configure-stage3-target-rda: maybe-all-stage3-target-libatomic
++configure-stage4-target-rda: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libada: maybe-all-stage1-target-libatomic
++configure-stage2-target-libada: maybe-all-stage2-target-libatomic
++configure-stage3-target-libada: maybe-all-stage3-target-libatomic
++configure-stage4-target-libada: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
++configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
++configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
++configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libssp: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
++
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
+ 
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
++
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
++configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
++configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
++configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
++configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
++configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
++configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
++configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
++configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
++configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
++configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
++configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
++configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
++configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
++configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
++configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-rda: maybe-all-stage1-target-libatomic
++configure-stage2-target-rda: maybe-all-stage2-target-libatomic
++configure-stage3-target-rda: maybe-all-stage3-target-libatomic
++configure-stage4-target-rda: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libada: maybe-all-stage1-target-libatomic
++configure-stage2-target-libada: maybe-all-stage2-target-libatomic
++configure-stage3-target-libada: maybe-all-stage3-target-libatomic
++configure-stage4-target-libada: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
++configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
++configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
++configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
+ 
+ configure-target-libbacktrace: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
++configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
++configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
++configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
++configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
++configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
++configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
++configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
++configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
++configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
++configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
++configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
++configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
++configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
++configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
++configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-rda: maybe-all-stage1-target-libatomic
++configure-stage2-target-rda: maybe-all-stage2-target-libatomic
++configure-stage3-target-rda: maybe-all-stage3-target-libatomic
++configure-stage4-target-rda: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libada: maybe-all-stage1-target-libatomic
++configure-stage2-target-libada: maybe-all-stage2-target-libatomic
++configure-stage3-target-libada: maybe-all-stage3-target-libatomic
++configure-stage4-target-libada: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
++configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
++configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
++configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libquadmath: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libgfortran: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libobjc: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libgo: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libphobos: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
++configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
++configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
++configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
++configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
++configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
++configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
++configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
++configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
++configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
++configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
++configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
++configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
++configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
++configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
++configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-rda: maybe-all-stage1-target-libatomic
++configure-stage2-target-rda: maybe-all-stage2-target-libatomic
++configure-stage3-target-rda: maybe-all-stage3-target-libatomic
++configure-stage4-target-rda: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libada: maybe-all-stage1-target-libatomic
++configure-stage2-target-libada: maybe-all-stage2-target-libatomic
++configure-stage3-target-libada: maybe-all-stage3-target-libatomic
++configure-stage4-target-libada: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
++configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
++configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
++configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libtermcap: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-winsup: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
++
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
+ 
+ configure-target-libffi: maybe-all-target-newlib maybe-all-target-libgloss
+ configure-target-libffi: maybe-all-target-libstdc++-v3
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-zlib: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
++configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
++configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
++configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
++configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
++configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
++configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
++configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
++configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
++configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
++configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
++configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
++configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
++configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
++configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
++configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-rda: maybe-all-stage1-target-libatomic
++configure-stage2-target-rda: maybe-all-stage2-target-libatomic
++configure-stage3-target-rda: maybe-all-stage3-target-libatomic
++configure-stage4-target-rda: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libada: maybe-all-stage1-target-libatomic
++configure-stage2-target-libada: maybe-all-stage2-target-libatomic
++configure-stage3-target-libada: maybe-all-stage3-target-libatomic
++configure-stage4-target-libada: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
++configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
++configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
++configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-rda: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libada: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libgm2: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libgomp: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
++configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
++configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
++configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
++configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
++configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
++configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
++configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
++configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
++configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
++configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
++configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
++configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
++configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
++configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
++configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-rda: maybe-all-stage1-target-libatomic
++configure-stage2-target-rda: maybe-all-stage2-target-libatomic
++configure-stage3-target-rda: maybe-all-stage3-target-libatomic
++configure-stage4-target-rda: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libada: maybe-all-stage1-target-libatomic
++configure-stage2-target-libada: maybe-all-stage2-target-libatomic
++configure-stage3-target-libada: maybe-all-stage3-target-libatomic
++configure-stage4-target-libada: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
++configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
++configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
++configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
 +
- dependencies = { module=configure-target-fastjar; on=configure-target-zlib; };
- dependencies = { module=all-target-fastjar; on=all-target-zlib; };
- dependencies = { module=configure-target-libgo; on=configure-target-libffi; };
-diff --git a/Makefile.in b/Makefile.in
-index 966d6045496..4a85f11d7e6 100644
---- a/Makefile.in
-+++ b/Makefile.in
-@@ -242,6 +242,7 @@ HOST_EXPORTS = \
- 	GMPINC="$(HOST_GMPINC)"; export GMPINC; \
- 	ISLLIBS="$(HOST_ISLLIBS)"; export ISLLIBS; \
- 	ISLINC="$(HOST_ISLINC)"; export ISLINC; \
-+	TARGET_CONFIGDIRS="$(TARGET_CONFIGDIRS)"; export TARGET_CONFIGDIRS; \
- 	XGCC_FLAGS_FOR_TARGET="$(XGCC_FLAGS_FOR_TARGET)"; export XGCC_FLAGS_FOR_TARGET; \
- @if gcc-bootstrap
- 	$(RPATH_ENVVAR)=`echo "$(TARGET_LIB_PATH)$$$(RPATH_ENVVAR)" | sed 's,::*,:,g;s,^:*,,;s,:*$$,,'`; export $(RPATH_ENVVAR); \
-@@ -68551,6 +68552,66 @@ all-flex: maybe-all-build-bison
- all-flex: maybe-all-m4
- all-flex: maybe-all-build-texinfo
- all-m4: maybe-all-build-texinfo
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
 +configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libitm: maybe-all-target-newlib maybe-all-target-libgloss
+ configure-target-libitm: maybe-all-target-libstdc++-v3
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
 +configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
 +configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
 +configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
@@ -90,7 +2957,24 @@ index 966d6045496..4a85f11d7e6 100644
 +configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
 +configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
 +configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
 +configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
 +configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
 +configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
@@ -100,7 +2984,43 @@ index 966d6045496..4a85f11d7e6 100644
 +configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
 +configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
 +configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
 +configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
++configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
++configure-target-libquadmath: maybe-all-target-libatomic
++configure-target-libgfortran: maybe-all-target-libatomic
++configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
++configure-target-libada: maybe-all-target-libatomic
++configure-target-libgm2: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libatomic: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
 +configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
 +configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
 +configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
@@ -110,7 +3030,6 @@ index 966d6045496..4a85f11d7e6 100644
 +configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
 +configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
 +configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
 +configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
 +configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
 +configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
@@ -120,7 +3039,60 @@ index 966d6045496..4a85f11d7e6 100644
 +configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
 +configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
 +configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
++configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
++configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
++configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
++configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
++configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
++configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
++configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
 +configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
 +configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
 +configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
@@ -130,7 +3102,33 @@ index 966d6045496..4a85f11d7e6 100644
 +configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
 +configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
 +configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
++configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
++configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
++configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
++configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
++configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
++configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
++configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
++configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
++configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
++configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
 +configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
 +configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
 +configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
@@ -140,77 +3138,181 @@ index 966d6045496..4a85f11d7e6 100644
 +configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
 +configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
 +configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
- configure-target-libgo: maybe-configure-target-libffi
- all-target-libgo: maybe-all-target-libffi
- configure-target-libphobos: maybe-configure-target-libbacktrace
-@@ -68678,6 +68739,45 @@ configure-m4: stage_last
- @endif gcc-bootstrap
- 
- @if gcc-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libgloss: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-newlib: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libitm: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libstdc++v3: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
++configure-stage1-target-rda: maybe-all-stage1-target-libatomic
++configure-stage2-target-rda: maybe-all-stage2-target-libatomic
++configure-stage3-target-rda: maybe-all-stage3-target-libatomic
++configure-stage4-target-rda: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libada: maybe-all-stage1-target-libatomic
++configure-stage2-target-libada: maybe-all-stage2-target-libatomic
++configure-stage3-target-libada: maybe-all-stage3-target-libatomic
++configure-stage4-target-libada: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
++configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
++configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
++configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
 +configure-target-libssp: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
++configure-target-libbacktrace: maybe-all-target-libatomic
 +configure-target-libquadmath: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
 +configure-target-libgfortran: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libffi: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
 +configure-target-libobjc: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
 +configure-target-libada: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
 +configure-target-libgm2: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libgo: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
-+@unless target-libatomic-bootstrap
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endunless target-libatomic-bootstrap
- @unless target-zlib-bootstrap
- configure-target-fastjar: maybe-configure-target-zlib
- @endunless target-zlib-bootstrap
-@@ -68755,6 +68855,19 @@ all-fastjar: maybe-all-libiberty
- all-bison: maybe-all-gettext
- all-flex: maybe-all-gettext
- all-m4: maybe-all-gettext
-+configure-target-libgloss: maybe-all-target-libatomic
-+configure-target-newlib: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
 +configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libstdc++v3: maybe-all-target-libatomic
++configure-target-libgrust: maybe-all-target-libatomic
++@endif gcc-no-bootstrap
++
+ configure-target-libgrust: maybe-all-target-newlib maybe-all-target-libgloss
+ 
++@if gcc-bootstrap
++configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
++configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
++configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
++configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
++configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
++configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
++configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
++configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
++configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
++configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
++configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
++configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
++configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
++configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
++configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
++configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
++configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
++configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
++configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
++configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
++configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
++configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
++configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
++configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
++configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
++configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
++configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
++configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap
++configure-target-libstdc++-v3: maybe-all-target-libatomic
++configure-target-libsanitizer: maybe-all-target-libatomic
++configure-target-libvtv: maybe-all-target-libatomic
 +configure-target-libssp: maybe-all-target-libatomic
++configure-target-libbacktrace: maybe-all-target-libatomic
 +configure-target-libquadmath: maybe-all-target-libatomic
 +configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
 +configure-target-libobjc: maybe-all-target-libatomic
++configure-target-libgo: maybe-all-target-libatomic
++configure-target-libphobos: maybe-all-target-libatomic
++configure-target-libtermcap: maybe-all-target-libatomic
++configure-target-winsup: maybe-all-target-libatomic
++configure-target-libffi: maybe-all-target-libatomic
++configure-target-zlib: maybe-all-target-libatomic
++configure-target-rda: maybe-all-target-libatomic
 +configure-target-libada: maybe-all-target-libatomic
 +configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
++configure-target-libgomp: maybe-all-target-libatomic
++configure-target-libitm: maybe-all-target-libatomic
 +configure-target-libgrust: maybe-all-target-libatomic
- configure-target-fastjar: maybe-configure-target-zlib
- all-target-fastjar: maybe-all-target-zlib
- configure-target-libgo: maybe-all-target-libstdc++-v3
++@endif gcc-no-bootstrap
++
+ 
+ CONFIGURE_GDB_TK = @CONFIGURE_GDB_TK@
+ GDB_TK = @GDB_TK@
 diff --git a/Makefile.tpl b/Makefile.tpl
-index da38dca697a..c6b2f7504ad 100644
+index da38dca697a..7edcfafb8e5 100644
 --- a/Makefile.tpl
 +++ b/Makefile.tpl
 @@ -245,6 +245,7 @@ HOST_EXPORTS = \
@@ -221,6 +3323,36 @@ index da38dca697a..c6b2f7504ad 100644
  	XGCC_FLAGS_FOR_TARGET="$(XGCC_FLAGS_FOR_TARGET)"; export XGCC_FLAGS_FOR_TARGET; \
  @if gcc-bootstrap
  	$(RPATH_ENVVAR)=`echo "$(TARGET_LIB_PATH)$$$(RPATH_ENVVAR)" | sed 's,::*,:,g;s,^:*,,;s,:*$$,,'`; export $(RPATH_ENVVAR); \
+@@ -2096,6 +2097,11 @@ ENDFOR dependencies +]@endif gcc-bootstrap
+    (if (exist? "no_gcc")
+        (hash-create-handle! lang-env-deps
+ 	  (string-append (get "module") "-" "no_gcc") #t))
++
++   (if (exist? "no_atomic")
++       (hash-create-handle! lang-env-deps
++	  (string-append (get "module") "-" "no_atomic") #t))
++
+    "" +][+ ENDFOR lang_env_dependencies +]
+ 
+ @if gcc-bootstrap[+ FOR target_modules +][+ IF (not (lang-dep "no_gcc"))
+@@ -2114,6 +2120,17 @@ configure-target-[+module+]: maybe-all-target-newlib maybe-all-target-libgloss[+
+   ENDIF +][+ IF (lang-dep "cxx") +]
+ configure-target-[+module+]: maybe-all-target-libstdc++-v3[+
+   ENDIF +]
++
++@if gcc-bootstrap[+ FOR target_modules +][+ IF (not (lang-dep "no_atomic"))
++  +][+ IF bootstrap +][+ FOR bootstrap_stage +]
++configure-stage[+id+]-target-[+module+]: maybe-all-stage[+id+]-target-libatomic[+
++  ENDFOR +][+ ENDIF bootstrap +][+ ENDIF +][+ ENDFOR target_modules +]
++@endif gcc-bootstrap
++
++@if gcc-no-bootstrap[+ FOR target_modules +][+ IF (not (lang-dep "no_atomic")) +]
++configure-target-[+module+]: maybe-all-target-libatomic[+
++  ENDIF +][+ ENDFOR target_modules +]
++@endif gcc-no-bootstrap
+ [+ ENDFOR target_modules +]
+ 
+ CONFIGURE_GDB_TK = @CONFIGURE_GDB_TK@
 diff --git a/configure b/configure
 index 4ae8e1242af..532e4527719 100755
 --- a/configure
@@ -254,7 +3386,7 @@ index 9a72b2311bd..c44d84f32ce 100644
  # or bootstrap-ubsan, bootstrap it.
  if echo " ${target_configdirs} " | grep " libsanitizer " > /dev/null 2>&1; then
 diff --git a/gcc/common.opt b/gcc/common.opt
-index 1b72826d44b..30530cc8b71 100644
+index e2ac99df1d0..cbb6a791c89 100644
 --- a/gcc/common.opt
 +++ b/gcc/common.opt
 @@ -3361,6 +3361,9 @@ Use the Modern linker (MOLD) linker instead of the default linker.
@@ -267,15 +3399,29 @@ index 1b72826d44b..30530cc8b71 100644
  ; Positive if we should track variables, negative if we should run
  ; the var-tracking pass only to discard debug annotations, zero if
  ; we're not to run it.
+diff --git a/gcc/common.opt.urls b/gcc/common.opt.urls
+index 79c322bed2b..0f076332abc 100644
+--- a/gcc/common.opt.urls
++++ b/gcc/common.opt.urls
+@@ -1573,6 +1573,9 @@ UrlSuffix(gcc/Link-Options.html#index-fuse-ld_003dmold)
+ fuse-linker-plugin
+ UrlSuffix(gcc/Optimize-Options.html#index-fuse-linker-plugin)
+ 
++flink-libatomic
++UrlSuffix(gcc/C-Dialect-Options.html#index-flink-libatomic)
++
+ fvar-tracking
+ UrlSuffix(gcc/Debugging-Options.html#index-fvar-tracking)
+ 
 diff --git a/gcc/config.in b/gcc/config.in
-index d8145a1453b..b5060d2c0c8 100644
+index 44de5a54611..621ca6f2b88 100644
 --- a/gcc/config.in
 +++ b/gcc/config.in
-@@ -2558,6 +2558,12 @@
+@@ -2565,6 +2565,12 @@
  #endif
  
  
-+/* Define if libatomic is built for the target */
++/* Define if libatomic is built for the target. */
 +#ifndef USED_FOR_TARGET
 +#undef TARGET_PROVIDES_LIBATOMIC
 +#endif
@@ -285,7 +3431,7 @@ index d8145a1453b..b5060d2c0c8 100644
  #ifndef USED_FOR_TARGET
  #undef TIME_WITH_SYS_TIME
 diff --git a/gcc/config/gnu-user.h b/gcc/config/gnu-user.h
-index f7eefdafe8b..27d0ef07e1e 100644
+index 4c4e31efa39..151871540e7 100644
 --- a/gcc/config/gnu-user.h
 +++ b/gcc/config/gnu-user.h
 @@ -109,8 +109,9 @@ see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
@@ -300,7 +3446,7 @@ index f7eefdafe8b..27d0ef07e1e 100644
  
  #undef LINK_GCC_C_SEQUENCE_SPEC
 diff --git a/gcc/configure b/gcc/configure
-index a8b531d8fae..6793d97820d 100755
+index a495762724d..d94f10c9ff1 100755
 --- a/gcc/configure
 +++ b/gcc/configure
 @@ -33420,6 +33420,12 @@ $as_echo "#define ENABLE_DEFAULT_SSP 1" >>confdefs.h
@@ -317,7 +3463,7 @@ index a8b531d8fae..6793d97820d 100755
  
  { $as_echo "$as_me:${as_lineno-$LINENO}: checking sys/sdt.h in the target C library" >&5
 diff --git a/gcc/configure.ac b/gcc/configure.ac
-index 77fab885a42..a6dd5786bd9 100644
+index 24261638096..537b8f79936 100644
 --- a/gcc/configure.ac
 +++ b/gcc/configure.ac
 @@ -7011,6 +7011,11 @@ if test x$enable_default_ssp = xyes ; then
@@ -326,14 +3472,14 @@ index 77fab885a42..a6dd5786bd9 100644
  
 +if echo " ${TARGET_CONFIGDIRS} " | grep " libatomic " > /dev/null 2>&1 ; then
 +  AC_DEFINE(TARGET_PROVIDES_LIBATOMIC, 1,
-+	    [Define if libatomic is built for the target])
++	    [Define if libatomic is built for the target.])
 +fi
 +
  # Test for <sys/sdt.h> on the target.
  GCC_TARGET_TEMPLATE([HAVE_SYS_SDT_H])
  AC_CACHE_CHECK([sys/sdt.h in the target C library], [gcc_cv_sys_sdt_h], [
 diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
-index 8ed5536365f..edf6c9f8684 100644
+index 0a7a81b2067..bb6b003dd7f 100644
 --- a/gcc/doc/invoke.texi
 +++ b/gcc/doc/invoke.texi
 @@ -206,7 +206,7 @@ in the following sections.
@@ -341,23 +3487,26 @@ index 8ed5536365f..edf6c9f8684 100644
  -fplan9-extensions  -fsigned-bitfields  -funsigned-bitfields
  -fsigned-char  -funsigned-char  -fstrict-flex-arrays[=@var{n}]
 --fsso-struct=@var{endianness}}
-+-flink-libatomic -fsso-struct=@var{endianness}}
++-fsso-struct=@var{endianness} -flink-libatomic}
  
  @item C++ Language Options
  @xref{C++ Dialect Options,,Options Controlling C++ Dialect}.
-@@ -2899,6 +2899,10 @@ The @option{-fstrict_flex_arrays} option interacts with the
+@@ -2900,6 +2900,13 @@ The @option{-fstrict_flex_arrays} option interacts with the
  @option{-Wstrict-flex-arrays} option.  @xref{Warning Options}, for more
  information.
  
 +@opindex flink-libatomic
 +@item -flink-libatomic
-+Enable linking of libatomic if it's supported by target. Enabled by default.
++Enable linking of libatomic if it's supported by target.  Enabled by default,
++and currently supported on targets using glibc. The negative form
++@option{-fno-link-libatomic} can be used to explicitly disable linking of
++libatomic.
 +
  @opindex fsso-struct
  @item -fsso-struct=@var{endianness}
  Set the default scalar storage order of structures and unions to the
 diff --git a/gcc/gcc.cc b/gcc/gcc.cc
-index 92c92996401..43d4c8763cb 100644
+index 95b98eaa83c..d7877d56b46 100644
 --- a/gcc/gcc.cc
 +++ b/gcc/gcc.cc
 @@ -980,6 +980,13 @@ proper position among the other output files.  */
@@ -375,7 +3524,7 @@ index 92c92996401..43d4c8763cb 100644
     -lgcc and -lc order specially, yet not require them to override all
     of LINK_COMMAND_SPEC.  */
 diff --git a/libatomic/Makefile.am b/libatomic/Makefile.am
-index efadd9dcd48..80bb6fbf477 100644
+index 0f1a7156084..5938f33ae7f 100644
 --- a/libatomic/Makefile.am
 +++ b/libatomic/Makefile.am
 @@ -69,7 +69,7 @@ libatomic_darwin_rpath += -Wl,-rpath,@loader_path
@@ -387,20 +3536,19 @@ index efadd9dcd48..80bb6fbf477 100644
  libatomic_la_SOURCES = gload.c gstore.c gcas.c gexch.c glfree.c lock.c init.c \
  	fenv.c fence.c flag.c
  
-@@ -162,6 +162,11 @@ libatomic_convenience_la_LIBADD = $(libatomic_la_LIBADD)
+@@ -162,6 +162,10 @@ libatomic_convenience_la_LIBADD = $(libatomic_la_LIBADD)
  # when it is reloaded during the build of all-multi.
  all-multi: $(libatomic_la_LIBADD)
  
-+gcc_objdir = $(MULTIBUILDTOP)../../$(host_subdir)/gcc
++gcc_objdir = `pwd`/$(MULTIBUILDTOP)../../gcc/
 +all: all-multi libatomic.la libatomic_convenience.la
-+	$(INSTALL_DATA) .libs/libatomic.a $(gcc_objdir)$(MULTISUBDIR)/
-+	chmod 644 $(gcc_objdir)$(MULTISUBDIR)/libatomic.a
++	$(LIBTOOL) --mode=install $(INSTALL_DATA) libatomic.la $(gcc_objdir)$(MULTISUBDIR)/
 +
  # target overrides
  -include $(tmake_file)
  
 diff --git a/libatomic/Makefile.in b/libatomic/Makefile.in
-index 9798e7c09e9..1d0494543d7 100644
+index 9798e7c09e9..fb2d447707e 100644
 --- a/libatomic/Makefile.in
 +++ b/libatomic/Makefile.in
 @@ -421,7 +421,7 @@ libatomic_version_info = -version-info $(libtool_VERSION)
@@ -416,22 +3564,21 @@ index 9798e7c09e9..1d0494543d7 100644
  @ARCH_X86_64_TRUE@@HAVE_IFUNC_TRUE@IFUNC_OPTIONS = -mcx16 -mcx16
  libatomic_convenience_la_SOURCES = $(libatomic_la_SOURCES)
  libatomic_convenience_la_LIBADD = $(libatomic_la_LIBADD)
-+gcc_objdir = $(MULTIBUILDTOP)../../$(host_subdir)/gcc
++gcc_objdir = `pwd`/$(MULTIBUILDTOP)../../gcc/
  MULTISRCTOP = 
  MULTIBUILDTOP = 
  MULTIDIRS = 
-@@ -901,6 +902,9 @@ vpath % $(strip $(search_path))
+@@ -901,6 +902,8 @@ vpath % $(strip $(search_path))
  # makefile fragments to avoid broken *.Ppo getting included into the Makefile
  # when it is reloaded during the build of all-multi.
  all-multi: $(libatomic_la_LIBADD)
 +all: all-multi libatomic.la libatomic_convenience.la
-+	$(INSTALL_DATA) .libs/libatomic.a $(gcc_objdir)$(MULTISUBDIR)/
-+	chmod 644 $(gcc_objdir)$(MULTISUBDIR)/libatomic.a
++	$(LIBTOOL) --mode=install $(INSTALL_DATA) libatomic.la $(gcc_objdir)$(MULTISUBDIR)/
  
  # target overrides
  -include $(tmake_file)
 diff --git a/libatomic/configure b/libatomic/configure
-index d579bab96f8..0a340276ca6 100755
+index d579bab96f8..90a5a3b479a 100755
 --- a/libatomic/configure
 +++ b/libatomic/configure
 @@ -3415,6 +3415,26 @@ esac
@@ -440,7 +3587,7 @@ index d579bab96f8..0a340276ca6 100755
  
 +# AC_PROG_CC sets CFLAGS to "-g -O2" by default (if unset), and
 +# then compile conftests with default CFLAGS, leaving no place to temporarily
-+# modify CFLAGS and restore them later. However we need to pass
++# modify CFLAGS and restore them later.  However we need to pass
 +# -fno-link-libatomic in CFLAGS so conftests compiled in AC_PROG_CC don't fail.
 +# Assert that CFLAGS is always set by user so the default setting of CFLAGS by
 +# AC_PROG_CC won't be applicable anyway.
@@ -492,7 +3639,7 @@ index d579bab96f8..0a340276ca6 100755
  
  #if HAVE_DLFCN_H
 diff --git a/libatomic/configure.ac b/libatomic/configure.ac
-index 32a2cdb13ae..23a9695be36 100644
+index aafae71028d..298b04097a9 100644
 --- a/libatomic/configure.ac
 +++ b/libatomic/configure.ac
 @@ -129,6 +129,26 @@ AC_SUBST(toolexeclibdir)
@@ -501,7 +3648,7 @@ index 32a2cdb13ae..23a9695be36 100644
  
 +# AC_PROG_CC sets CFLAGS to "-g -O2" by default (if unset), and
 +# then compile conftests with default CFLAGS, leaving no place to temporarily
-+# modify CFLAGS and restore them later. However we need to pass
++# modify CFLAGS and restore them later.  However we need to pass
 +# -fno-link-libatomic in CFLAGS so conftests compiled in AC_PROG_CC don't fail.
 +# Assert that CFLAGS is always set by user so the default setting of CFLAGS by
 +# AC_PROG_CC won't be applicable anyway.
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 2789ef2..5580afb 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 39	????
 
+	U 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
 	- 82_all_PR118409-ifcombine.patch
 
 38	13 January 2023
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-14  8:43 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-14  8:43 UTC (permalink / raw
  To: gentoo-commits
commit:     45c3db3dbbdcb7c6a692987a05a40cfb2bdaa034
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jan 14 08:43:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jan 14 08:43:30 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=45c3db3d
15.0.0: add two more ifcombine patches
Bug: https://gcc.gnu.org/PR118456
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...xtend-constants-to-compare-with-bitfields.patch | 214 +++++++++++++
 ...PR118456-robustify-decode_field_reference.patch | 354 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   2 +
 3 files changed, 570 insertions(+)
diff --git a/15.0.0/gentoo/84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch b/15.0.0/gentoo/84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
new file mode 100644
index 0000000..e005c02
--- /dev/null
+++ b/15.0.0/gentoo/84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
@@ -0,0 +1,214 @@
+https://inbox.sourceware.org/gcc-patches/ora5bugmmi.fsf@lxoliva.fsfla.org/
+
+From 4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192 Mon Sep 17 00:00:00 2001
+Message-ID: <4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192.1736844127.git.sam@gentoo.org>
+From: Alexandre Oliva <oliva@adacore.com>
+Date: Mon, 13 Jan 2025 23:22:45 -0300
+Subject: [PATCH 1/2] check and extend constants to compare with bitfields
+ [PR118456]
+
+Add logic to check and extend constants compared with bitfields, so
+that fields are only compared with constants they could actually
+equal.  This involves making sure the signedness doesn't change
+between loads and conversions before shifts: we'd need to carry a lot
+more data to deal with all the possibilities.
+
+Regstrapped on x86_64-linux-gnu.  Ok to install?
+
+for  gcc/ChangeLog
+
+	PR tree-optimization/118456
+	* gimple-fold.cc (decode_field_reference): Punt if shifting
+	after changing signedness.
+	(fold_truth_andor_for_ifcombine): Check extension bits in
+	constants before clipping.
+
+for  gcc/testsuite/ChangeLog
+
+PR tree-optimization/118456
+	* gcc.dg/field-merge-21.c: New.
+	* gcc.dg/field-merge-22.c: New.
+---
+ gcc/gimple-fold.cc                    | 40 +++++++++++++++++++-
+ gcc/testsuite/gcc.dg/field-merge-21.c | 53 +++++++++++++++++++++++++++
+ gcc/testsuite/gcc.dg/field-merge-22.c | 31 ++++++++++++++++
+ 3 files changed, 122 insertions(+), 2 deletions(-)
+ create mode 100644 gcc/testsuite/gcc.dg/field-merge-21.c
+ create mode 100644 gcc/testsuite/gcc.dg/field-merge-22.c
+
+diff --git a/gcc/gimple-fold.cc b/gcc/gimple-fold.cc
+index 93ed8b3abb05..5b1fbe6db1df 100644
+--- a/gcc/gimple-fold.cc
++++ b/gcc/gimple-fold.cc
+@@ -7712,6 +7712,18 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+ 
+   if (shiftrt)
+     {
++      /* Punt if we're shifting by more than the loaded bitfield (after
++	 adjustment), or if there's a shift after a change of signedness, punt.
++	 When comparing this field with a constant, we'll check that the
++	 constant is a proper sign- or zero-extension (depending on signedness)
++	 of a value that would fit in the selected portion of the bitfield.  A
++	 shift after a change of signedness would make the extension
++	 non-uniform, and we can't deal with that (yet ???).  See
++	 gcc.dg/field-merge-22.c for a test that would go wrong.  */
++      if (*pbitsize <= shiftrt
++	  || (convert_before_shift
++	      && outer_type && unsignedp != TYPE_UNSIGNED (outer_type)))
++	return NULL_TREE;
+       if (!*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
+ 	*pbitpos += shiftrt;
+       *pbitsize -= shiftrt;
+@@ -8512,13 +8524,25 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+      and bit position.  */
+   if (l_const.get_precision ())
+     {
++      /* Before clipping upper bits of the right-hand operand of the compare,
++	 check that they're sign or zero extensions, depending on how the
++	 left-hand operand would be extended.  */
++      bool l_non_ext_bits = false;
++      if (ll_bitsize < lr_bitsize)
++	{
++	  wide_int zext = wi::zext (l_const, ll_bitsize);
++	  if ((ll_unsignedp ? zext : wi::sext (l_const, ll_bitsize)) == l_const)
++	    l_const = zext;
++	  else
++	    l_non_ext_bits = true;
++	}
+       /* We're doing bitwise equality tests, so don't bother with sign
+ 	 extensions.  */
+       l_const = wide_int::from (l_const, lnprec, UNSIGNED);
+       if (ll_and_mask.get_precision ())
+ 	l_const &= wide_int::from (ll_and_mask, lnprec, UNSIGNED);
+       l_const <<= xll_bitpos;
+-      if ((l_const & ~ll_mask) != 0)
++      if (l_non_ext_bits || (l_const & ~ll_mask) != 0)
+ 	{
+ 	  warning_at (lloc, OPT_Wtautological_compare,
+ 		      "comparison is always %d", wanted_code == NE_EXPR);
+@@ -8530,11 +8554,23 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+ 	 again.  */
+       gcc_checking_assert (r_const.get_precision ());
+ 
++      /* Before clipping upper bits of the right-hand operand of the compare,
++	 check that they're sign or zero extensions, depending on how the
++	 left-hand operand would be extended.  */
++      bool r_non_ext_bits = false;
++      if (rl_bitsize < rr_bitsize)
++	{
++	  wide_int zext = wi::zext (r_const, rl_bitsize);
++	  if ((rl_unsignedp ? zext : wi::sext (r_const, rl_bitsize)) == r_const)
++	    r_const = zext;
++	  else
++	    r_non_ext_bits = true;
++	}
+       r_const = wide_int::from (r_const, lnprec, UNSIGNED);
+       if (rl_and_mask.get_precision ())
+ 	r_const &= wide_int::from (rl_and_mask, lnprec, UNSIGNED);
+       r_const <<= xrl_bitpos;
+-      if ((r_const & ~rl_mask) != 0)
++      if (r_non_ext_bits || (r_const & ~rl_mask) != 0)
+ 	{
+ 	  warning_at (rloc, OPT_Wtautological_compare,
+ 		      "comparison is always %d", wanted_code == NE_EXPR);
+diff --git a/gcc/testsuite/gcc.dg/field-merge-21.c b/gcc/testsuite/gcc.dg/field-merge-21.c
+new file mode 100644
+index 000000000000..042b2123eb63
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/field-merge-21.c
+@@ -0,0 +1,53 @@
++/* { dg-do run } */
++/* { dg-options "-O2" } */
++
++/* PR tree-optimization/118456 */
++/* Check that shifted fields compared with a constants compare correctly even
++   if the constant contains sign-extension bits not present in the bit
++   range.  */
++
++struct S { unsigned long long o; unsigned short a, b; } s;
++
++__attribute__((noipa)) int
++foo (void)
++{
++  return ((unsigned char) s.a) >> 3 == 17 && ((signed char) s.b) >> 2 == -27;
++}
++
++__attribute__((noipa)) int
++bar (void)
++{
++  return ((unsigned char) s.a) >> 3 == 17 && ((signed char) s.b) >> 2 == -91;
++}
++
++__attribute__((noipa)) int
++bars (void)
++{
++  return ((unsigned char) s.a) >> 3 == 17 && ((signed char) s.b) >> 2 == 37;
++}
++
++__attribute__((noipa)) int
++baz (void)
++{
++  return ((unsigned char) s.a) >> 3 == 49 && ((signed char) s.b) >> 2 == -27;
++}
++
++__attribute__((noipa)) int
++bazs (void)
++{
++  return ((unsigned char) s.a) >> 3 == (unsigned char) -15 && ((signed char) s.b) >> 2 == -27;
++}
++
++int
++main ()
++{
++  s.a = 17 << 3;
++  s.b = (unsigned short)(-27u << 2);
++  if (foo () != 1
++      || bar () != 0
++      || bars () != 0
++      || baz () != 0
++      || bazs () != 0)
++    __builtin_abort ();
++  return 0;
++}
+diff --git a/gcc/testsuite/gcc.dg/field-merge-22.c b/gcc/testsuite/gcc.dg/field-merge-22.c
+new file mode 100644
+index 000000000000..45b29c0bccaf
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/field-merge-22.c
+@@ -0,0 +1,31 @@
++/* { dg-do run } */
++/* { dg-options "-O2" } */
++
++/* PR tree-optimization/118456 */
++/* Check that compares with constants take into account sign/zero extension of
++   both the bitfield and of the shifting type.  */
++
++#define shift (__CHAR_BIT__ - 4)
++
++struct S {
++  signed char a : shift + 2;
++  signed char b : shift + 2;
++  short ignore[0];
++} s;
++
++__attribute__((noipa)) int
++foo (void)
++{
++  return ((unsigned char) s.a) >> shift == 15
++    && ((unsigned char) s.b) >> shift == 0;
++}
++
++int
++main ()
++{
++  s.a = -1;
++  s.b = 1;
++  if (foo () != 1)
++    __builtin_abort ();
++  return 0;
++}
+
+base-commit: 31c3c1a83fd885b4687c9f6f7acd68af76d758d3
+-- 
+2.48.0
+
diff --git a/15.0.0/gentoo/85_all_PR118456-robustify-decode_field_reference.patch b/15.0.0/gentoo/85_all_PR118456-robustify-decode_field_reference.patch
new file mode 100644
index 0000000..065c958
--- /dev/null
+++ b/15.0.0/gentoo/85_all_PR118456-robustify-decode_field_reference.patch
@@ -0,0 +1,354 @@
+https://inbox.sourceware.org/gcc-patches/or1px6gf6r.fsf@lxoliva.fsfla.org/
+
+From e3a5a707fd88522a73d05841970fa2465e991eaa Mon Sep 17 00:00:00 2001
+Message-ID: <e3a5a707fd88522a73d05841970fa2465e991eaa.1736844127.git.sam@gentoo.org>
+In-Reply-To: <4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192.1736844127.git.sam@gentoo.org>
+References: <4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192.1736844127.git.sam@gentoo.org>
+From: Alexandre Oliva <oliva@adacore.com>
+Date: Tue, 14 Jan 2025 02:03:24 -0300
+Subject: [PATCH 2/2] robustify decode_field_reference
+
+Arrange for decode_field_reference to use local variables throughout,
+to modify the out parms only when we're about to return non-NULL, and
+to drop the unused case of NULL pand_mask, that had a latent failure
+to detect signbit masking.
+
+Regstrapped on x86_64-linux-gnu along with the PR118456 patch.
+Ok to install?
+
+for  gcc/ChangeLog
+
+* gimple-fold.cc (decode_field_reference): Rebustify to set
+	out parms only when returning non-NULL.
+	(fold_truth_andor_for_ifcombine): Bail if
+	decode_field_reference returns NULL.  Add complementary assert
+	on r_const's not being set when l_const isn't.
+---
+ gcc/gimple-fold.cc | 155 +++++++++++++++++++++++----------------------
+ 1 file changed, 80 insertions(+), 75 deletions(-)
+
+diff --git a/gcc/gimple-fold.cc b/gcc/gimple-fold.cc
+index 5b1fbe6db1df..3c971a29ef04 100644
+--- a/gcc/gimple-fold.cc
++++ b/gcc/gimple-fold.cc
+@@ -7510,18 +7510,17 @@ gimple_binop_def_p (enum tree_code code, tree t, tree op[2])
+    *PREVERSEP is set to the storage order of the field.
+ 
+    *PAND_MASK is set to the mask found in a BIT_AND_EXPR, if any.  If
+-   PAND_MASK *is NULL, BIT_AND_EXPR is not recognized.  If *PAND_MASK
+-   is initially set to a mask with nonzero precision, that mask is
++   *PAND_MASK is initially set to a mask with nonzero precision, that mask is
+    combined with the found mask, or adjusted in precision to match.
+ 
+    *PSIGNBIT is set to TRUE if, before clipping to *PBITSIZE, the mask
+    encompassed bits that corresponded to extensions of the sign bit.
+ 
+-   *XOR_P is to be FALSE if EXP might be a XOR used in a compare, in which
+-   case, if XOR_CMP_OP is a zero constant, it will be overridden with *PEXP,
+-   *XOR_P will be set to TRUE, *XOR_PAND_MASK will be copied from *PAND_MASK,
+-   and the left-hand operand of the XOR will be decoded.  If *XOR_P is TRUE,
+-   XOR_CMP_OP and XOR_PAND_MASK are supposed to be NULL, and then the
++   *PXORP is to be FALSE if EXP might be a XOR used in a compare, in which
++   case, if PXOR_CMP_OP is a zero constant, it will be overridden with *PEXP,
++   *PXORP will be set to TRUE, *PXOR_AND_MASK will be copied from *PAND_MASK,
++   and the left-hand operand of the XOR will be decoded.  If *PXORP is TRUE,
++   PXOR_CMP_OP and PXOR_AND_MASK are supposed to be NULL, and then the
+    right-hand operand of the XOR will be decoded.
+ 
+    *LOAD is set to the load stmt of the innermost reference, if any,
+@@ -7538,8 +7537,8 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+ 			HOST_WIDE_INT *pbitpos,
+ 			bool *punsignedp, bool *preversep, bool *pvolatilep,
+ 			wide_int *pand_mask, bool *psignbit,
+-			bool *xor_p, tree *xor_cmp_op, wide_int *xor_pand_mask,
+-			gimple **load, location_t loc[4])
++			bool *pxorp, tree *pxor_cmp_op, wide_int *pxor_and_mask,
++			gimple **pload, location_t loc[4])
+ {
+   tree exp = *pexp;
+   tree outer_type = 0;
+@@ -7549,9 +7548,11 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+   tree res_ops[2];
+   machine_mode mode;
+   bool convert_before_shift = false;
+-
+-  *load = NULL;
+-  *psignbit = false;
++  bool signbit = false;
++  bool xorp = false;
++  tree xor_cmp_op;
++  wide_int xor_and_mask;
++  gimple *load = NULL;
+ 
+   /* All the optimizations using this function assume integer fields.
+      There are problems with FP fields since the type_for_size call
+@@ -7576,7 +7577,7 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+ 
+   /* Recognize and save a masking operation.  Combine it with an
+      incoming mask.  */
+-  if (pand_mask && gimple_binop_def_p (BIT_AND_EXPR, exp, res_ops)
++  if (gimple_binop_def_p (BIT_AND_EXPR, exp, res_ops)
+       && TREE_CODE (res_ops[1]) == INTEGER_CST)
+     {
+       loc[1] = gimple_location (SSA_NAME_DEF_STMT (exp));
+@@ -7596,29 +7597,29 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+ 	    and_mask &= wide_int::from (*pand_mask, prec_op, UNSIGNED);
+ 	}
+     }
+-  else if (pand_mask)
++  else
+     and_mask = *pand_mask;
+ 
+   /* Turn (a ^ b) [!]= 0 into a [!]= b.  */
+-  if (xor_p && gimple_binop_def_p (BIT_XOR_EXPR, exp, res_ops))
++  if (pxorp && gimple_binop_def_p (BIT_XOR_EXPR, exp, res_ops))
+     {
+       /* No location recorded for this one, it's entirely subsumed by the
+ 	 compare.  */
+-      if (*xor_p)
++      if (*pxorp)
+ 	{
+ 	  exp = res_ops[1];
+-	  gcc_checking_assert (!xor_cmp_op && !xor_pand_mask);
++	  gcc_checking_assert (!pxor_cmp_op && !pxor_and_mask);
+ 	}
+-      else if (!xor_cmp_op)
++      else if (!pxor_cmp_op)
+ 	/* Not much we can do when xor appears in the right-hand compare
+ 	   operand.  */
+ 	return NULL_TREE;
+-      else if (integer_zerop (*xor_cmp_op))
++      else if (integer_zerop (*pxor_cmp_op))
+ 	{
+-	  *xor_p = true;
++	  xorp = true;
+ 	  exp = res_ops[0];
+-	  *xor_cmp_op = *pexp;
+-	  *xor_pand_mask = *pand_mask;
++	  xor_cmp_op = *pexp;
++	  xor_and_mask = *pand_mask;
+ 	}
+     }
+ 
+@@ -7646,12 +7647,12 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+   /* Yet another chance to drop conversions.  This one is allowed to
+      match a converting load, subsuming the load identification block
+      below.  */
+-  if (!outer_type && gimple_convert_def_p (exp, res_ops, load))
++  if (!outer_type && gimple_convert_def_p (exp, res_ops, &load))
+     {
+       outer_type = TREE_TYPE (exp);
+       loc[0] = gimple_location (SSA_NAME_DEF_STMT (exp));
+-      if (*load)
+-	loc[3] = gimple_location (*load);
++      if (load)
++	loc[3] = gimple_location (load);
+       exp = res_ops[0];
+       /* This looks backwards, but we're going back the def chain, so if we
+ 	 find the conversion here, after finding a shift, that's because the
+@@ -7662,14 +7663,13 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+     }
+ 
+   /* Identify the load, if there is one.  */
+-  if (!(*load) && TREE_CODE (exp) == SSA_NAME
+-      && !SSA_NAME_IS_DEFAULT_DEF (exp))
++  if (!load && TREE_CODE (exp) == SSA_NAME && !SSA_NAME_IS_DEFAULT_DEF (exp))
+     {
+       gimple *def = SSA_NAME_DEF_STMT (exp);
+       if (gimple_assign_load_p (def))
+ 	{
+ 	  loc[3] = gimple_location (def);
+-	  *load = def;
++	  load = def;
+ 	  exp = gimple_assign_rhs1 (def);
+ 	}
+     }
+@@ -7694,20 +7694,14 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+ 	  && !type_has_mode_precision_p (TREE_TYPE (inner))))
+     return NULL_TREE;
+ 
+-  *pbitsize = bs;
+-  *pbitpos = bp;
+-  *punsignedp = unsignedp;
+-  *preversep = reversep;
+-  *pvolatilep = volatilep;
+-
+   /* Adjust shifts...  */
+   if (convert_before_shift
+-      && outer_type && *pbitsize > TYPE_PRECISION (outer_type))
++      && outer_type && bs > TYPE_PRECISION (outer_type))
+     {
+-      HOST_WIDE_INT excess = *pbitsize - TYPE_PRECISION (outer_type);
+-      if (*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
+-	*pbitpos += excess;
+-      *pbitsize -= excess;
++      HOST_WIDE_INT excess = bs - TYPE_PRECISION (outer_type);
++      if (reversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
++	bp += excess;
++      bs -= excess;
+     }
+ 
+   if (shiftrt)
+@@ -7720,49 +7714,57 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+ 	 shift after a change of signedness would make the extension
+ 	 non-uniform, and we can't deal with that (yet ???).  See
+ 	 gcc.dg/field-merge-22.c for a test that would go wrong.  */
+-      if (*pbitsize <= shiftrt
++      if (bs <= shiftrt
+ 	  || (convert_before_shift
+ 	      && outer_type && unsignedp != TYPE_UNSIGNED (outer_type)))
+ 	return NULL_TREE;
+-      if (!*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
+-	*pbitpos += shiftrt;
+-      *pbitsize -= shiftrt;
++      if (!reversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
++	bp += shiftrt;
++      bs -= shiftrt;
+     }
+ 
+   /* ... and bit position.  */
+   if (!convert_before_shift
+-      && outer_type && *pbitsize > TYPE_PRECISION (outer_type))
++      && outer_type && bs > TYPE_PRECISION (outer_type))
+     {
+-      HOST_WIDE_INT excess = *pbitsize - TYPE_PRECISION (outer_type);
+-      if (*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
+-	*pbitpos += excess;
+-      *pbitsize -= excess;
++      HOST_WIDE_INT excess = bs - TYPE_PRECISION (outer_type);
++      if (reversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
++	bp += excess;
++      bs -= excess;
+     }
+ 
+-  *pexp = exp;
+-
+   /* If the number of bits in the reference is the same as the bitsize of
+      the outer type, then the outer type gives the signedness. Otherwise
+      (in case of a small bitfield) the signedness is unchanged.  */
+-  if (outer_type && *pbitsize == TYPE_PRECISION (outer_type))
+-    *punsignedp = TYPE_UNSIGNED (outer_type);
++  if (outer_type && bs == TYPE_PRECISION (outer_type))
++    unsignedp = TYPE_UNSIGNED (outer_type);
+ 
+-  if (pand_mask)
++  /* Make the mask the expected width.  */
++  if (and_mask.get_precision () != 0)
+     {
+-      /* Make the mask the expected width.  */
+-      if (and_mask.get_precision () != 0)
+-	{
+-	  /* If the AND_MASK encompasses bits that would be extensions of
+-	     the sign bit, set *PSIGNBIT.  */
+-	  if (!unsignedp
+-	      && and_mask.get_precision () > *pbitsize
+-	      && (and_mask
+-		  & wi::mask (*pbitsize, true, and_mask.get_precision ())) != 0)
+-	    *psignbit = true;
+-	  and_mask = wide_int::from (and_mask, *pbitsize, UNSIGNED);
+-	}
++      /* If the AND_MASK encompasses bits that would be extensions of
++	 the sign bit, set SIGNBIT.  */
++      if (!unsignedp
++	  && and_mask.get_precision () > bs
++	  && (and_mask & wi::mask (bs, true, and_mask.get_precision ())) != 0)
++	signbit = true;
++      and_mask = wide_int::from (and_mask, bs, UNSIGNED);
++    }
+ 
+-      *pand_mask = and_mask;
++  *pexp = exp;
++  *pload = load;
++  *pbitsize = bs;
++  *pbitpos = bp;
++  *punsignedp = unsignedp;
++  *preversep = reversep;
++  *pvolatilep = volatilep;
++  *psignbit = signbit;
++  *pand_mask = and_mask;
++  if (xorp)
++    {
++      *pxorp = xorp;
++      *pxor_cmp_op = xor_cmp_op;
++      *pxor_and_mask = xor_and_mask;
+     }
+ 
+   return inner;
+@@ -8168,19 +8170,27 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+ 				     &ll_and_mask, &ll_signbit,
+ 				     &l_xor, &lr_arg, &lr_and_mask,
+ 				     &ll_load, ll_loc);
++  if (!ll_inner)
++    return 0;
+   lr_inner = decode_field_reference (&lr_arg, &lr_bitsize, &lr_bitpos,
+ 				     &lr_unsignedp, &lr_reversep, &volatilep,
+ 				     &lr_and_mask, &lr_signbit, &l_xor, 0, 0,
+ 				     &lr_load, lr_loc);
++  if (!lr_inner)
++    return 0;
+   rl_inner = decode_field_reference (&rl_arg, &rl_bitsize, &rl_bitpos,
+ 				     &rl_unsignedp, &rl_reversep, &volatilep,
+ 				     &rl_and_mask, &rl_signbit,
+ 				     &r_xor, &rr_arg, &rr_and_mask,
+ 				     &rl_load, rl_loc);
++  if (!rl_inner)
++    return 0;
+   rr_inner = decode_field_reference (&rr_arg, &rr_bitsize, &rr_bitpos,
+ 				     &rr_unsignedp, &rr_reversep, &volatilep,
+ 				     &rr_and_mask, &rr_signbit, &r_xor, 0, 0,
+ 				     &rr_load, rr_loc);
++  if (!rr_inner)
++    return 0;
+ 
+   /* It must be true that the inner operation on the lhs of each
+      comparison must be the same if we are to be able to do anything.
+@@ -8188,16 +8198,13 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+      the rhs's.  If one is a load and the other isn't, we have to be
+      conservative and avoid the optimization, otherwise we could get
+      SRAed fields wrong.  */
+-  if (volatilep
+-      || ll_reversep != rl_reversep
+-      || ll_inner == 0 || rl_inner == 0)
++  if (volatilep || ll_reversep != rl_reversep)
+     return 0;
+ 
+   if (! operand_equal_p (ll_inner, rl_inner, 0))
+     {
+       /* Try swapping the operands.  */
+       if (ll_reversep != rr_reversep
+-	  || !rr_inner
+ 	  || !operand_equal_p (ll_inner, rr_inner, 0))
+ 	return 0;
+ 
+@@ -8266,7 +8273,6 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+       lr_reversep = ll_reversep;
+     }
+   else if (lr_reversep != rr_reversep
+-	   || lr_inner == 0 || rr_inner == 0
+ 	   || ! operand_equal_p (lr_inner, rr_inner, 0)
+ 	   || ((lr_load && rr_load)
+ 	       ? gimple_vuse (lr_load) != gimple_vuse (rr_load)
+@@ -8520,6 +8526,9 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+   else
+     rl_mask = wi::shifted_mask (xrl_bitpos, rl_bitsize, false, lnprec);
+ 
++  /* When we set l_const, we also set r_const.  */
++  gcc_checking_assert (!l_const.get_precision () == !r_const.get_precision ());
++
+   /* Adjust right-hand constants in both original comparisons to match width
+      and bit position.  */
+   if (l_const.get_precision ())
+@@ -8550,10 +8559,6 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+ 	  return constant_boolean_node (wanted_code == NE_EXPR, truth_type);
+ 	}
+ 
+-      /* When we set l_const, we also set r_const, so we need not test it
+-	 again.  */
+-      gcc_checking_assert (r_const.get_precision ());
+-
+       /* Before clipping upper bits of the right-hand operand of the compare,
+ 	 check that they're sign or zero extensions, depending on how the
+ 	 left-hand operand would be extended.  */
+-- 
+2.48.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 5580afb..490735a 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -2,6 +2,8 @@
 
 	U 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
 	- 82_all_PR118409-ifcombine.patch
+	+ 84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
+	+ 85_all_PR118456-robustify-decode_field_reference.patch
 
 38	13 January 2023
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-14 12:29 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-14 12:29 UTC (permalink / raw
  To: gentoo-commits
commit:     5d9547668e061e63f81fcbfb5519b85fd99ab3ab
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jan 14 12:28:41 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jan 14 12:28:41 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=5d954766
15.0.0: cut patchset 39
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 490735a..e33ee2c 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,11 +1,11 @@
-39	????
+39	14 January 2025
 
 	U 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
 	- 82_all_PR118409-ifcombine.patch
 	+ 84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
 	+ 85_all_PR118456-robustify-decode_field_reference.patch
 
-38	13 January 2023
+38	13 January 2025
 
 	+ 82_all_PR118409-ifcombine.patch
 	+ 83_all-gcc-d-give-dependency-files-better-filenames.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-14 15:06 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-14 15:06 UTC (permalink / raw
  To: gentoo-commits
commit:     3f4aa6c706b52c74e689588667597255dd1007e0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jan 14 15:05:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jan 14 15:05:58 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=3f4aa6c7
15.0.0: add patch to fix m68k cross
This is already in trunk but I want to backport it (no revbump though
given it stops the build w/ checking).
Bug: https://gcc.gnu.org/PR118418
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch | 87 ++++++++++++++++++++++
 15.0.0/gentoo/README.history                       |  4 +
 2 files changed, 91 insertions(+)
diff --git a/15.0.0/gentoo/86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch b/15.0.0/gentoo/86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
new file mode 100644
index 0000000..ce0b338
--- /dev/null
+++ b/15.0.0/gentoo/86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
@@ -0,0 +1,87 @@
+From a1a14ce3c39c25fecf052ffde063fc0ecfc2ffa3 Mon Sep 17 00:00:00 2001
+Message-ID: <a1a14ce3c39c25fecf052ffde063fc0ecfc2ffa3.1736867096.git.sam@gentoo.org>
+From: Richard Sandiford <richard.sandiford@arm.com>
+Date: Mon, 13 Jan 2025 19:37:12 +0000
+Subject: [PATCH] Fix build for STORE_FLAG_VALUE<0 targets [PR118418]
+
+In g:06c4cf398947b53b4bfc65752f9f879bb2d07924 I mishandled signed
+comparisons of comparison results on STORE_FLAG_VALUE < 0 targets
+(despite specifically referencing STORE_FLAG_VALUE in the commit
+message).  There, (lt TRUE FALSE) is true, although (ltu FALSE TRUE)
+still holds.
+
+Things get messy with vector modes, and since those weren't the focus
+of the original commit, it seemed better to punt on them for now.
+However, punting means that this optimisation no longer feels like
+a natural tail-call operation.  The patch therefore converts
+"return simplify..." to the usual call-and-conditional-return pattern.
+
+gcc/
+	PR target/118418
+	* simplify-rtx.cc (simplify_context::simplify_relational_operation_1):
+	Take STORE_FLAG_VALUE into account when handling signed comparisons
+	of comparison results.
+---
+ gcc/simplify-rtx.cc | 39 ++++++++++++++++++++++++---------------
+ 1 file changed, 24 insertions(+), 15 deletions(-)
+
+diff --git a/gcc/simplify-rtx.cc b/gcc/simplify-rtx.cc
+index 71c5d3c1b1b8..dda8fc689e79 100644
+--- a/gcc/simplify-rtx.cc
++++ b/gcc/simplify-rtx.cc
+@@ -6434,7 +6434,7 @@ simplify_context::simplify_relational_operation_1 (rtx_code code,
+ 	return simplify_gen_binary (AND, mode, XEXP (tmp, 0), const1_rtx);
+     }
+ 
+-  /* For two booleans A and B:
++  /* For two unsigned booleans A and B:
+ 
+      A >  B == ~B & A
+      A >= B == ~B | A
+@@ -6443,20 +6443,29 @@ simplify_context::simplify_relational_operation_1 (rtx_code code,
+      A == B == ~A ^ B (== ~B ^ A)
+      A != B ==  A ^ B
+ 
+-     simplify_logical_relational_operation checks whether A and B
+-     are booleans.  */
+-  if (code == GTU || code == GT)
+-    return simplify_logical_relational_operation (AND, mode, op1, op0, true);
+-  if (code == GEU || code == GE)
+-    return simplify_logical_relational_operation (IOR, mode, op1, op0, true);
+-  if (code == LTU || code == LT)
+-    return simplify_logical_relational_operation (AND, mode, op0, op1, true);
+-  if (code == LEU || code == LE)
+-    return simplify_logical_relational_operation (IOR, mode, op0, op1, true);
+-  if (code == EQ)
+-    return simplify_logical_relational_operation (XOR, mode, op0, op1, true);
+-  if (code == NE)
+-    return simplify_logical_relational_operation (XOR, mode, op0, op1);
++     For signed comparisons, we have to take STORE_FLAG_VALUE into account,
++     with the rules above applying for positive STORE_FLAG_VALUE and with
++     the relations reversed for negative STORE_FLAG_VALUE.  */
++  if (is_a<scalar_int_mode> (cmp_mode)
++      && COMPARISON_P (op0)
++      && COMPARISON_P (op1))
++    {
++      rtx t = NULL_RTX;
++      if (code == GTU || code == (STORE_FLAG_VALUE > 0 ? GT : LT))
++	t = simplify_logical_relational_operation (AND, mode, op1, op0, true);
++      else if (code == GEU || code == (STORE_FLAG_VALUE > 0 ? GE : LE))
++	t = simplify_logical_relational_operation (IOR, mode, op1, op0, true);
++      else if (code == LTU || code == (STORE_FLAG_VALUE > 0 ? LT : GT))
++	t = simplify_logical_relational_operation (AND, mode, op0, op1, true);
++      else if (code == LEU || code == (STORE_FLAG_VALUE > 0 ? LE : GE))
++	t = simplify_logical_relational_operation (IOR, mode, op0, op1, true);
++      else if (code == EQ)
++	t = simplify_logical_relational_operation (XOR, mode, op0, op1, true);
++      else if (code == NE)
++	t = simplify_logical_relational_operation (XOR, mode, op0, op1);
++      if (t)
++	return t;
++    }
+ 
+   return NULL_RTX;
+ }
+-- 
+2.48.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index e33ee2c..1d5c985 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+40	14 January 2025
+
+	+ 86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
+
 39	14 January 2025
 
 	U 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-14 15:06 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-14 15:06 UTC (permalink / raw
  To: gentoo-commits
commit:     98a192aae9698ea3961ab037cd44029c76cf3db4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jan 14 15:06:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jan 14 15:06:37 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=98a192aa
15.0.0: drop patch merged upstream
3f4aa6c706b52c74e689588667597255dd1007e0 was purely to backport it
to the last snapshot.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch | 87 ----------------------
 15.0.0/gentoo/README.history                       |  4 +
 2 files changed, 4 insertions(+), 87 deletions(-)
diff --git a/15.0.0/gentoo/86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch b/15.0.0/gentoo/86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
deleted file mode 100644
index ce0b338..0000000
--- a/15.0.0/gentoo/86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
+++ /dev/null
@@ -1,87 +0,0 @@
-From a1a14ce3c39c25fecf052ffde063fc0ecfc2ffa3 Mon Sep 17 00:00:00 2001
-Message-ID: <a1a14ce3c39c25fecf052ffde063fc0ecfc2ffa3.1736867096.git.sam@gentoo.org>
-From: Richard Sandiford <richard.sandiford@arm.com>
-Date: Mon, 13 Jan 2025 19:37:12 +0000
-Subject: [PATCH] Fix build for STORE_FLAG_VALUE<0 targets [PR118418]
-
-In g:06c4cf398947b53b4bfc65752f9f879bb2d07924 I mishandled signed
-comparisons of comparison results on STORE_FLAG_VALUE < 0 targets
-(despite specifically referencing STORE_FLAG_VALUE in the commit
-message).  There, (lt TRUE FALSE) is true, although (ltu FALSE TRUE)
-still holds.
-
-Things get messy with vector modes, and since those weren't the focus
-of the original commit, it seemed better to punt on them for now.
-However, punting means that this optimisation no longer feels like
-a natural tail-call operation.  The patch therefore converts
-"return simplify..." to the usual call-and-conditional-return pattern.
-
-gcc/
-	PR target/118418
-	* simplify-rtx.cc (simplify_context::simplify_relational_operation_1):
-	Take STORE_FLAG_VALUE into account when handling signed comparisons
-	of comparison results.
----
- gcc/simplify-rtx.cc | 39 ++++++++++++++++++++++++---------------
- 1 file changed, 24 insertions(+), 15 deletions(-)
-
-diff --git a/gcc/simplify-rtx.cc b/gcc/simplify-rtx.cc
-index 71c5d3c1b1b8..dda8fc689e79 100644
---- a/gcc/simplify-rtx.cc
-+++ b/gcc/simplify-rtx.cc
-@@ -6434,7 +6434,7 @@ simplify_context::simplify_relational_operation_1 (rtx_code code,
- 	return simplify_gen_binary (AND, mode, XEXP (tmp, 0), const1_rtx);
-     }
- 
--  /* For two booleans A and B:
-+  /* For two unsigned booleans A and B:
- 
-      A >  B == ~B & A
-      A >= B == ~B | A
-@@ -6443,20 +6443,29 @@ simplify_context::simplify_relational_operation_1 (rtx_code code,
-      A == B == ~A ^ B (== ~B ^ A)
-      A != B ==  A ^ B
- 
--     simplify_logical_relational_operation checks whether A and B
--     are booleans.  */
--  if (code == GTU || code == GT)
--    return simplify_logical_relational_operation (AND, mode, op1, op0, true);
--  if (code == GEU || code == GE)
--    return simplify_logical_relational_operation (IOR, mode, op1, op0, true);
--  if (code == LTU || code == LT)
--    return simplify_logical_relational_operation (AND, mode, op0, op1, true);
--  if (code == LEU || code == LE)
--    return simplify_logical_relational_operation (IOR, mode, op0, op1, true);
--  if (code == EQ)
--    return simplify_logical_relational_operation (XOR, mode, op0, op1, true);
--  if (code == NE)
--    return simplify_logical_relational_operation (XOR, mode, op0, op1);
-+     For signed comparisons, we have to take STORE_FLAG_VALUE into account,
-+     with the rules above applying for positive STORE_FLAG_VALUE and with
-+     the relations reversed for negative STORE_FLAG_VALUE.  */
-+  if (is_a<scalar_int_mode> (cmp_mode)
-+      && COMPARISON_P (op0)
-+      && COMPARISON_P (op1))
-+    {
-+      rtx t = NULL_RTX;
-+      if (code == GTU || code == (STORE_FLAG_VALUE > 0 ? GT : LT))
-+	t = simplify_logical_relational_operation (AND, mode, op1, op0, true);
-+      else if (code == GEU || code == (STORE_FLAG_VALUE > 0 ? GE : LE))
-+	t = simplify_logical_relational_operation (IOR, mode, op1, op0, true);
-+      else if (code == LTU || code == (STORE_FLAG_VALUE > 0 ? LT : GT))
-+	t = simplify_logical_relational_operation (AND, mode, op0, op1, true);
-+      else if (code == LEU || code == (STORE_FLAG_VALUE > 0 ? LE : GE))
-+	t = simplify_logical_relational_operation (IOR, mode, op0, op1, true);
-+      else if (code == EQ)
-+	t = simplify_logical_relational_operation (XOR, mode, op0, op1, true);
-+      else if (code == NE)
-+	t = simplify_logical_relational_operation (XOR, mode, op0, op1);
-+      if (t)
-+	return t;
-+    }
- 
-   return NULL_RTX;
- }
--- 
-2.48.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 1d5c985..0607277 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+41	????
+
+	- 86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
+
 40	14 January 2025
 
 	+ 86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-14 16:22 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-14 16:22 UTC (permalink / raw
  To: gentoo-commits
commit:     5c4e50d6f18794b3bece70beadb05d256087f45d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jan 14 16:22:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jan 14 16:22:17 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=5c4e50d6
15.0.0: drop upstream ifcombine patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...xtend-constants-to-compare-with-bitfields.patch | 214 ---------------------
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 1 insertion(+), 214 deletions(-)
diff --git a/15.0.0/gentoo/84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch b/15.0.0/gentoo/84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
deleted file mode 100644
index e005c02..0000000
--- a/15.0.0/gentoo/84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
+++ /dev/null
@@ -1,214 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/ora5bugmmi.fsf@lxoliva.fsfla.org/
-
-From 4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192 Mon Sep 17 00:00:00 2001
-Message-ID: <4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192.1736844127.git.sam@gentoo.org>
-From: Alexandre Oliva <oliva@adacore.com>
-Date: Mon, 13 Jan 2025 23:22:45 -0300
-Subject: [PATCH 1/2] check and extend constants to compare with bitfields
- [PR118456]
-
-Add logic to check and extend constants compared with bitfields, so
-that fields are only compared with constants they could actually
-equal.  This involves making sure the signedness doesn't change
-between loads and conversions before shifts: we'd need to carry a lot
-more data to deal with all the possibilities.
-
-Regstrapped on x86_64-linux-gnu.  Ok to install?
-
-for  gcc/ChangeLog
-
-	PR tree-optimization/118456
-	* gimple-fold.cc (decode_field_reference): Punt if shifting
-	after changing signedness.
-	(fold_truth_andor_for_ifcombine): Check extension bits in
-	constants before clipping.
-
-for  gcc/testsuite/ChangeLog
-
-PR tree-optimization/118456
-	* gcc.dg/field-merge-21.c: New.
-	* gcc.dg/field-merge-22.c: New.
----
- gcc/gimple-fold.cc                    | 40 +++++++++++++++++++-
- gcc/testsuite/gcc.dg/field-merge-21.c | 53 +++++++++++++++++++++++++++
- gcc/testsuite/gcc.dg/field-merge-22.c | 31 ++++++++++++++++
- 3 files changed, 122 insertions(+), 2 deletions(-)
- create mode 100644 gcc/testsuite/gcc.dg/field-merge-21.c
- create mode 100644 gcc/testsuite/gcc.dg/field-merge-22.c
-
-diff --git a/gcc/gimple-fold.cc b/gcc/gimple-fold.cc
-index 93ed8b3abb05..5b1fbe6db1df 100644
---- a/gcc/gimple-fold.cc
-+++ b/gcc/gimple-fold.cc
-@@ -7712,6 +7712,18 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
- 
-   if (shiftrt)
-     {
-+      /* Punt if we're shifting by more than the loaded bitfield (after
-+	 adjustment), or if there's a shift after a change of signedness, punt.
-+	 When comparing this field with a constant, we'll check that the
-+	 constant is a proper sign- or zero-extension (depending on signedness)
-+	 of a value that would fit in the selected portion of the bitfield.  A
-+	 shift after a change of signedness would make the extension
-+	 non-uniform, and we can't deal with that (yet ???).  See
-+	 gcc.dg/field-merge-22.c for a test that would go wrong.  */
-+      if (*pbitsize <= shiftrt
-+	  || (convert_before_shift
-+	      && outer_type && unsignedp != TYPE_UNSIGNED (outer_type)))
-+	return NULL_TREE;
-       if (!*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
- 	*pbitpos += shiftrt;
-       *pbitsize -= shiftrt;
-@@ -8512,13 +8524,25 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
-      and bit position.  */
-   if (l_const.get_precision ())
-     {
-+      /* Before clipping upper bits of the right-hand operand of the compare,
-+	 check that they're sign or zero extensions, depending on how the
-+	 left-hand operand would be extended.  */
-+      bool l_non_ext_bits = false;
-+      if (ll_bitsize < lr_bitsize)
-+	{
-+	  wide_int zext = wi::zext (l_const, ll_bitsize);
-+	  if ((ll_unsignedp ? zext : wi::sext (l_const, ll_bitsize)) == l_const)
-+	    l_const = zext;
-+	  else
-+	    l_non_ext_bits = true;
-+	}
-       /* We're doing bitwise equality tests, so don't bother with sign
- 	 extensions.  */
-       l_const = wide_int::from (l_const, lnprec, UNSIGNED);
-       if (ll_and_mask.get_precision ())
- 	l_const &= wide_int::from (ll_and_mask, lnprec, UNSIGNED);
-       l_const <<= xll_bitpos;
--      if ((l_const & ~ll_mask) != 0)
-+      if (l_non_ext_bits || (l_const & ~ll_mask) != 0)
- 	{
- 	  warning_at (lloc, OPT_Wtautological_compare,
- 		      "comparison is always %d", wanted_code == NE_EXPR);
-@@ -8530,11 +8554,23 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
- 	 again.  */
-       gcc_checking_assert (r_const.get_precision ());
- 
-+      /* Before clipping upper bits of the right-hand operand of the compare,
-+	 check that they're sign or zero extensions, depending on how the
-+	 left-hand operand would be extended.  */
-+      bool r_non_ext_bits = false;
-+      if (rl_bitsize < rr_bitsize)
-+	{
-+	  wide_int zext = wi::zext (r_const, rl_bitsize);
-+	  if ((rl_unsignedp ? zext : wi::sext (r_const, rl_bitsize)) == r_const)
-+	    r_const = zext;
-+	  else
-+	    r_non_ext_bits = true;
-+	}
-       r_const = wide_int::from (r_const, lnprec, UNSIGNED);
-       if (rl_and_mask.get_precision ())
- 	r_const &= wide_int::from (rl_and_mask, lnprec, UNSIGNED);
-       r_const <<= xrl_bitpos;
--      if ((r_const & ~rl_mask) != 0)
-+      if (r_non_ext_bits || (r_const & ~rl_mask) != 0)
- 	{
- 	  warning_at (rloc, OPT_Wtautological_compare,
- 		      "comparison is always %d", wanted_code == NE_EXPR);
-diff --git a/gcc/testsuite/gcc.dg/field-merge-21.c b/gcc/testsuite/gcc.dg/field-merge-21.c
-new file mode 100644
-index 000000000000..042b2123eb63
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/field-merge-21.c
-@@ -0,0 +1,53 @@
-+/* { dg-do run } */
-+/* { dg-options "-O2" } */
-+
-+/* PR tree-optimization/118456 */
-+/* Check that shifted fields compared with a constants compare correctly even
-+   if the constant contains sign-extension bits not present in the bit
-+   range.  */
-+
-+struct S { unsigned long long o; unsigned short a, b; } s;
-+
-+__attribute__((noipa)) int
-+foo (void)
-+{
-+  return ((unsigned char) s.a) >> 3 == 17 && ((signed char) s.b) >> 2 == -27;
-+}
-+
-+__attribute__((noipa)) int
-+bar (void)
-+{
-+  return ((unsigned char) s.a) >> 3 == 17 && ((signed char) s.b) >> 2 == -91;
-+}
-+
-+__attribute__((noipa)) int
-+bars (void)
-+{
-+  return ((unsigned char) s.a) >> 3 == 17 && ((signed char) s.b) >> 2 == 37;
-+}
-+
-+__attribute__((noipa)) int
-+baz (void)
-+{
-+  return ((unsigned char) s.a) >> 3 == 49 && ((signed char) s.b) >> 2 == -27;
-+}
-+
-+__attribute__((noipa)) int
-+bazs (void)
-+{
-+  return ((unsigned char) s.a) >> 3 == (unsigned char) -15 && ((signed char) s.b) >> 2 == -27;
-+}
-+
-+int
-+main ()
-+{
-+  s.a = 17 << 3;
-+  s.b = (unsigned short)(-27u << 2);
-+  if (foo () != 1
-+      || bar () != 0
-+      || bars () != 0
-+      || baz () != 0
-+      || bazs () != 0)
-+    __builtin_abort ();
-+  return 0;
-+}
-diff --git a/gcc/testsuite/gcc.dg/field-merge-22.c b/gcc/testsuite/gcc.dg/field-merge-22.c
-new file mode 100644
-index 000000000000..45b29c0bccaf
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/field-merge-22.c
-@@ -0,0 +1,31 @@
-+/* { dg-do run } */
-+/* { dg-options "-O2" } */
-+
-+/* PR tree-optimization/118456 */
-+/* Check that compares with constants take into account sign/zero extension of
-+   both the bitfield and of the shifting type.  */
-+
-+#define shift (__CHAR_BIT__ - 4)
-+
-+struct S {
-+  signed char a : shift + 2;
-+  signed char b : shift + 2;
-+  short ignore[0];
-+} s;
-+
-+__attribute__((noipa)) int
-+foo (void)
-+{
-+  return ((unsigned char) s.a) >> shift == 15
-+    && ((unsigned char) s.b) >> shift == 0;
-+}
-+
-+int
-+main ()
-+{
-+  s.a = -1;
-+  s.b = 1;
-+  if (foo () != 1)
-+    __builtin_abort ();
-+  return 0;
-+}
-
-base-commit: 31c3c1a83fd885b4687c9f6f7acd68af76d758d3
--- 
-2.48.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 0607277..02c646e 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 41	????
 
+	- 84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
 	- 86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
 
 40	14 January 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-15 11:41 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-15 11:41 UTC (permalink / raw
  To: gentoo-commits
commit:     2e47edeb6aa67d66f1ebe828137dd296fd9bb4dc
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 15 11:41:11 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jan 15 11:41:35 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=2e47edeb
15.0.0: drop another upstream ifcombine patch
It got committed a bit later than the previous.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...PR118456-robustify-decode_field_reference.patch | 354 ---------------------
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 1 insertion(+), 354 deletions(-)
diff --git a/15.0.0/gentoo/85_all_PR118456-robustify-decode_field_reference.patch b/15.0.0/gentoo/85_all_PR118456-robustify-decode_field_reference.patch
deleted file mode 100644
index 065c958..0000000
--- a/15.0.0/gentoo/85_all_PR118456-robustify-decode_field_reference.patch
+++ /dev/null
@@ -1,354 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/or1px6gf6r.fsf@lxoliva.fsfla.org/
-
-From e3a5a707fd88522a73d05841970fa2465e991eaa Mon Sep 17 00:00:00 2001
-Message-ID: <e3a5a707fd88522a73d05841970fa2465e991eaa.1736844127.git.sam@gentoo.org>
-In-Reply-To: <4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192.1736844127.git.sam@gentoo.org>
-References: <4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192.1736844127.git.sam@gentoo.org>
-From: Alexandre Oliva <oliva@adacore.com>
-Date: Tue, 14 Jan 2025 02:03:24 -0300
-Subject: [PATCH 2/2] robustify decode_field_reference
-
-Arrange for decode_field_reference to use local variables throughout,
-to modify the out parms only when we're about to return non-NULL, and
-to drop the unused case of NULL pand_mask, that had a latent failure
-to detect signbit masking.
-
-Regstrapped on x86_64-linux-gnu along with the PR118456 patch.
-Ok to install?
-
-for  gcc/ChangeLog
-
-* gimple-fold.cc (decode_field_reference): Rebustify to set
-	out parms only when returning non-NULL.
-	(fold_truth_andor_for_ifcombine): Bail if
-	decode_field_reference returns NULL.  Add complementary assert
-	on r_const's not being set when l_const isn't.
----
- gcc/gimple-fold.cc | 155 +++++++++++++++++++++++----------------------
- 1 file changed, 80 insertions(+), 75 deletions(-)
-
-diff --git a/gcc/gimple-fold.cc b/gcc/gimple-fold.cc
-index 5b1fbe6db1df..3c971a29ef04 100644
---- a/gcc/gimple-fold.cc
-+++ b/gcc/gimple-fold.cc
-@@ -7510,18 +7510,17 @@ gimple_binop_def_p (enum tree_code code, tree t, tree op[2])
-    *PREVERSEP is set to the storage order of the field.
- 
-    *PAND_MASK is set to the mask found in a BIT_AND_EXPR, if any.  If
--   PAND_MASK *is NULL, BIT_AND_EXPR is not recognized.  If *PAND_MASK
--   is initially set to a mask with nonzero precision, that mask is
-+   *PAND_MASK is initially set to a mask with nonzero precision, that mask is
-    combined with the found mask, or adjusted in precision to match.
- 
-    *PSIGNBIT is set to TRUE if, before clipping to *PBITSIZE, the mask
-    encompassed bits that corresponded to extensions of the sign bit.
- 
--   *XOR_P is to be FALSE if EXP might be a XOR used in a compare, in which
--   case, if XOR_CMP_OP is a zero constant, it will be overridden with *PEXP,
--   *XOR_P will be set to TRUE, *XOR_PAND_MASK will be copied from *PAND_MASK,
--   and the left-hand operand of the XOR will be decoded.  If *XOR_P is TRUE,
--   XOR_CMP_OP and XOR_PAND_MASK are supposed to be NULL, and then the
-+   *PXORP is to be FALSE if EXP might be a XOR used in a compare, in which
-+   case, if PXOR_CMP_OP is a zero constant, it will be overridden with *PEXP,
-+   *PXORP will be set to TRUE, *PXOR_AND_MASK will be copied from *PAND_MASK,
-+   and the left-hand operand of the XOR will be decoded.  If *PXORP is TRUE,
-+   PXOR_CMP_OP and PXOR_AND_MASK are supposed to be NULL, and then the
-    right-hand operand of the XOR will be decoded.
- 
-    *LOAD is set to the load stmt of the innermost reference, if any,
-@@ -7538,8 +7537,8 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
- 			HOST_WIDE_INT *pbitpos,
- 			bool *punsignedp, bool *preversep, bool *pvolatilep,
- 			wide_int *pand_mask, bool *psignbit,
--			bool *xor_p, tree *xor_cmp_op, wide_int *xor_pand_mask,
--			gimple **load, location_t loc[4])
-+			bool *pxorp, tree *pxor_cmp_op, wide_int *pxor_and_mask,
-+			gimple **pload, location_t loc[4])
- {
-   tree exp = *pexp;
-   tree outer_type = 0;
-@@ -7549,9 +7548,11 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
-   tree res_ops[2];
-   machine_mode mode;
-   bool convert_before_shift = false;
--
--  *load = NULL;
--  *psignbit = false;
-+  bool signbit = false;
-+  bool xorp = false;
-+  tree xor_cmp_op;
-+  wide_int xor_and_mask;
-+  gimple *load = NULL;
- 
-   /* All the optimizations using this function assume integer fields.
-      There are problems with FP fields since the type_for_size call
-@@ -7576,7 +7577,7 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
- 
-   /* Recognize and save a masking operation.  Combine it with an
-      incoming mask.  */
--  if (pand_mask && gimple_binop_def_p (BIT_AND_EXPR, exp, res_ops)
-+  if (gimple_binop_def_p (BIT_AND_EXPR, exp, res_ops)
-       && TREE_CODE (res_ops[1]) == INTEGER_CST)
-     {
-       loc[1] = gimple_location (SSA_NAME_DEF_STMT (exp));
-@@ -7596,29 +7597,29 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
- 	    and_mask &= wide_int::from (*pand_mask, prec_op, UNSIGNED);
- 	}
-     }
--  else if (pand_mask)
-+  else
-     and_mask = *pand_mask;
- 
-   /* Turn (a ^ b) [!]= 0 into a [!]= b.  */
--  if (xor_p && gimple_binop_def_p (BIT_XOR_EXPR, exp, res_ops))
-+  if (pxorp && gimple_binop_def_p (BIT_XOR_EXPR, exp, res_ops))
-     {
-       /* No location recorded for this one, it's entirely subsumed by the
- 	 compare.  */
--      if (*xor_p)
-+      if (*pxorp)
- 	{
- 	  exp = res_ops[1];
--	  gcc_checking_assert (!xor_cmp_op && !xor_pand_mask);
-+	  gcc_checking_assert (!pxor_cmp_op && !pxor_and_mask);
- 	}
--      else if (!xor_cmp_op)
-+      else if (!pxor_cmp_op)
- 	/* Not much we can do when xor appears in the right-hand compare
- 	   operand.  */
- 	return NULL_TREE;
--      else if (integer_zerop (*xor_cmp_op))
-+      else if (integer_zerop (*pxor_cmp_op))
- 	{
--	  *xor_p = true;
-+	  xorp = true;
- 	  exp = res_ops[0];
--	  *xor_cmp_op = *pexp;
--	  *xor_pand_mask = *pand_mask;
-+	  xor_cmp_op = *pexp;
-+	  xor_and_mask = *pand_mask;
- 	}
-     }
- 
-@@ -7646,12 +7647,12 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
-   /* Yet another chance to drop conversions.  This one is allowed to
-      match a converting load, subsuming the load identification block
-      below.  */
--  if (!outer_type && gimple_convert_def_p (exp, res_ops, load))
-+  if (!outer_type && gimple_convert_def_p (exp, res_ops, &load))
-     {
-       outer_type = TREE_TYPE (exp);
-       loc[0] = gimple_location (SSA_NAME_DEF_STMT (exp));
--      if (*load)
--	loc[3] = gimple_location (*load);
-+      if (load)
-+	loc[3] = gimple_location (load);
-       exp = res_ops[0];
-       /* This looks backwards, but we're going back the def chain, so if we
- 	 find the conversion here, after finding a shift, that's because the
-@@ -7662,14 +7663,13 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
-     }
- 
-   /* Identify the load, if there is one.  */
--  if (!(*load) && TREE_CODE (exp) == SSA_NAME
--      && !SSA_NAME_IS_DEFAULT_DEF (exp))
-+  if (!load && TREE_CODE (exp) == SSA_NAME && !SSA_NAME_IS_DEFAULT_DEF (exp))
-     {
-       gimple *def = SSA_NAME_DEF_STMT (exp);
-       if (gimple_assign_load_p (def))
- 	{
- 	  loc[3] = gimple_location (def);
--	  *load = def;
-+	  load = def;
- 	  exp = gimple_assign_rhs1 (def);
- 	}
-     }
-@@ -7694,20 +7694,14 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
- 	  && !type_has_mode_precision_p (TREE_TYPE (inner))))
-     return NULL_TREE;
- 
--  *pbitsize = bs;
--  *pbitpos = bp;
--  *punsignedp = unsignedp;
--  *preversep = reversep;
--  *pvolatilep = volatilep;
--
-   /* Adjust shifts...  */
-   if (convert_before_shift
--      && outer_type && *pbitsize > TYPE_PRECISION (outer_type))
-+      && outer_type && bs > TYPE_PRECISION (outer_type))
-     {
--      HOST_WIDE_INT excess = *pbitsize - TYPE_PRECISION (outer_type);
--      if (*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
--	*pbitpos += excess;
--      *pbitsize -= excess;
-+      HOST_WIDE_INT excess = bs - TYPE_PRECISION (outer_type);
-+      if (reversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
-+	bp += excess;
-+      bs -= excess;
-     }
- 
-   if (shiftrt)
-@@ -7720,49 +7714,57 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
- 	 shift after a change of signedness would make the extension
- 	 non-uniform, and we can't deal with that (yet ???).  See
- 	 gcc.dg/field-merge-22.c for a test that would go wrong.  */
--      if (*pbitsize <= shiftrt
-+      if (bs <= shiftrt
- 	  || (convert_before_shift
- 	      && outer_type && unsignedp != TYPE_UNSIGNED (outer_type)))
- 	return NULL_TREE;
--      if (!*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
--	*pbitpos += shiftrt;
--      *pbitsize -= shiftrt;
-+      if (!reversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
-+	bp += shiftrt;
-+      bs -= shiftrt;
-     }
- 
-   /* ... and bit position.  */
-   if (!convert_before_shift
--      && outer_type && *pbitsize > TYPE_PRECISION (outer_type))
-+      && outer_type && bs > TYPE_PRECISION (outer_type))
-     {
--      HOST_WIDE_INT excess = *pbitsize - TYPE_PRECISION (outer_type);
--      if (*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
--	*pbitpos += excess;
--      *pbitsize -= excess;
-+      HOST_WIDE_INT excess = bs - TYPE_PRECISION (outer_type);
-+      if (reversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
-+	bp += excess;
-+      bs -= excess;
-     }
- 
--  *pexp = exp;
--
-   /* If the number of bits in the reference is the same as the bitsize of
-      the outer type, then the outer type gives the signedness. Otherwise
-      (in case of a small bitfield) the signedness is unchanged.  */
--  if (outer_type && *pbitsize == TYPE_PRECISION (outer_type))
--    *punsignedp = TYPE_UNSIGNED (outer_type);
-+  if (outer_type && bs == TYPE_PRECISION (outer_type))
-+    unsignedp = TYPE_UNSIGNED (outer_type);
- 
--  if (pand_mask)
-+  /* Make the mask the expected width.  */
-+  if (and_mask.get_precision () != 0)
-     {
--      /* Make the mask the expected width.  */
--      if (and_mask.get_precision () != 0)
--	{
--	  /* If the AND_MASK encompasses bits that would be extensions of
--	     the sign bit, set *PSIGNBIT.  */
--	  if (!unsignedp
--	      && and_mask.get_precision () > *pbitsize
--	      && (and_mask
--		  & wi::mask (*pbitsize, true, and_mask.get_precision ())) != 0)
--	    *psignbit = true;
--	  and_mask = wide_int::from (and_mask, *pbitsize, UNSIGNED);
--	}
-+      /* If the AND_MASK encompasses bits that would be extensions of
-+	 the sign bit, set SIGNBIT.  */
-+      if (!unsignedp
-+	  && and_mask.get_precision () > bs
-+	  && (and_mask & wi::mask (bs, true, and_mask.get_precision ())) != 0)
-+	signbit = true;
-+      and_mask = wide_int::from (and_mask, bs, UNSIGNED);
-+    }
- 
--      *pand_mask = and_mask;
-+  *pexp = exp;
-+  *pload = load;
-+  *pbitsize = bs;
-+  *pbitpos = bp;
-+  *punsignedp = unsignedp;
-+  *preversep = reversep;
-+  *pvolatilep = volatilep;
-+  *psignbit = signbit;
-+  *pand_mask = and_mask;
-+  if (xorp)
-+    {
-+      *pxorp = xorp;
-+      *pxor_cmp_op = xor_cmp_op;
-+      *pxor_and_mask = xor_and_mask;
-     }
- 
-   return inner;
-@@ -8168,19 +8170,27 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
- 				     &ll_and_mask, &ll_signbit,
- 				     &l_xor, &lr_arg, &lr_and_mask,
- 				     &ll_load, ll_loc);
-+  if (!ll_inner)
-+    return 0;
-   lr_inner = decode_field_reference (&lr_arg, &lr_bitsize, &lr_bitpos,
- 				     &lr_unsignedp, &lr_reversep, &volatilep,
- 				     &lr_and_mask, &lr_signbit, &l_xor, 0, 0,
- 				     &lr_load, lr_loc);
-+  if (!lr_inner)
-+    return 0;
-   rl_inner = decode_field_reference (&rl_arg, &rl_bitsize, &rl_bitpos,
- 				     &rl_unsignedp, &rl_reversep, &volatilep,
- 				     &rl_and_mask, &rl_signbit,
- 				     &r_xor, &rr_arg, &rr_and_mask,
- 				     &rl_load, rl_loc);
-+  if (!rl_inner)
-+    return 0;
-   rr_inner = decode_field_reference (&rr_arg, &rr_bitsize, &rr_bitpos,
- 				     &rr_unsignedp, &rr_reversep, &volatilep,
- 				     &rr_and_mask, &rr_signbit, &r_xor, 0, 0,
- 				     &rr_load, rr_loc);
-+  if (!rr_inner)
-+    return 0;
- 
-   /* It must be true that the inner operation on the lhs of each
-      comparison must be the same if we are to be able to do anything.
-@@ -8188,16 +8198,13 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
-      the rhs's.  If one is a load and the other isn't, we have to be
-      conservative and avoid the optimization, otherwise we could get
-      SRAed fields wrong.  */
--  if (volatilep
--      || ll_reversep != rl_reversep
--      || ll_inner == 0 || rl_inner == 0)
-+  if (volatilep || ll_reversep != rl_reversep)
-     return 0;
- 
-   if (! operand_equal_p (ll_inner, rl_inner, 0))
-     {
-       /* Try swapping the operands.  */
-       if (ll_reversep != rr_reversep
--	  || !rr_inner
- 	  || !operand_equal_p (ll_inner, rr_inner, 0))
- 	return 0;
- 
-@@ -8266,7 +8273,6 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
-       lr_reversep = ll_reversep;
-     }
-   else if (lr_reversep != rr_reversep
--	   || lr_inner == 0 || rr_inner == 0
- 	   || ! operand_equal_p (lr_inner, rr_inner, 0)
- 	   || ((lr_load && rr_load)
- 	       ? gimple_vuse (lr_load) != gimple_vuse (rr_load)
-@@ -8520,6 +8526,9 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
-   else
-     rl_mask = wi::shifted_mask (xrl_bitpos, rl_bitsize, false, lnprec);
- 
-+  /* When we set l_const, we also set r_const.  */
-+  gcc_checking_assert (!l_const.get_precision () == !r_const.get_precision ());
-+
-   /* Adjust right-hand constants in both original comparisons to match width
-      and bit position.  */
-   if (l_const.get_precision ())
-@@ -8550,10 +8559,6 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
- 	  return constant_boolean_node (wanted_code == NE_EXPR, truth_type);
- 	}
- 
--      /* When we set l_const, we also set r_const, so we need not test it
--	 again.  */
--      gcc_checking_assert (r_const.get_precision ());
--
-       /* Before clipping upper bits of the right-hand operand of the compare,
- 	 check that they're sign or zero extensions, depending on how the
- 	 left-hand operand would be extended.  */
--- 
-2.48.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 02c646e..a3e5131 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 41	????
 
 	- 84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
+	- 85_all_PR118456-robustify-decode_field_reference.patch
 	- 86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
 
 40	14 January 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-16 23:11 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-16 23:11 UTC (permalink / raw
  To: gentoo-commits
commit:     e42dbea5f6e2a59e7a2aafe1f406ddf697a2658e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jan 16 23:04:53 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jan 16 23:07:49 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=e42dbea5
15.0.0: fix ifcombine patches again
Apparently I lost 82_all_PR118409-ifcombine.patch. Bring the patches
back to respin the patchset...
This reverts commit 2e47edeb6aa67d66f1ebe828137dd296fd9bb4dc temporarily.
This reverts commit 5c4e50d6f18794b3bece70beadb05d256087f45d temporarily.
This reverts commit 98a192aae9698ea3961ab037cd44029c76cf3db4 temporarily.
Cloess: https://bugs.gentoo.org/948147
Closes: https://bugs.gentoo.org/948202
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/82_all_PR118409-ifcombine.patch      | 154 +++++++++
 ...xtend-constants-to-compare-with-bitfields.patch | 214 +++++++++++++
 ...PR118456-robustify-decode_field_reference.patch | 354 +++++++++++++++++++++
 ...-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch |  87 +++++
 15.0.0/gentoo/README.history                       |   6 +-
 5 files changed, 811 insertions(+), 4 deletions(-)
diff --git a/15.0.0/gentoo/82_all_PR118409-ifcombine.patch b/15.0.0/gentoo/82_all_PR118409-ifcombine.patch
new file mode 100644
index 0000000..6362cd1
--- /dev/null
+++ b/15.0.0/gentoo/82_all_PR118409-ifcombine.patch
@@ -0,0 +1,154 @@
+https://inbox.sourceware.org/gcc-patches/ored17gz9x.fsf@lxoliva.fsfla.org/
+
+From bfb791ad941348a0bb854b770f2294424528bc40 Mon Sep 17 00:00:00 2001
+Message-ID: <bfb791ad941348a0bb854b770f2294424528bc40.1736739564.git.sam@gentoo.org>
+From: Alexandre Oliva <oliva@adacore.com>
+Date: Mon, 13 Jan 2025 00:37:14 -0300
+Subject: [PATCH] propagate signbit mask to XOR right-hand operand
+
+If a single-bit bitfield takes up the sign bit of a storage unit,
+comparing the corresponding bitfield between two objects loads the
+storage units, XORs them, converts the result to signed char, and
+compares it with zero: ((signed char)(a.<byte> ^ c.<byte>) >= 0).
+
+fold_truth_andor_for_ifcombine recognizes the compare with zero as a
+sign bit test, then it decomposes the XOR into an equality test.
+
+The problem is that, after this decomposition, that figures out the
+width of the accessed fields, we apply the sign bit mask to the
+left-hand operand of the compare, but we failed to also apply it to
+the right-hand operand when both were taken from the same XOR.
+
+This patch fixes that.
+
+Regstrapped on x86_64-linux-gnu.  Ok to install?
+
+for  gcc/ChangeLog
+
+	PR tree-optimization/118409
+	* gimple-fold.cc (fold_truth_andor_for_ifcombine): Apply the
+	signbit mask to the right-hand XOR operand too.
+
+for  gcc/testsuite/ChangeLog
+
+PR tree-optimization/118409
+	* gcc.dg/field-merge-20.c: New.
+---
+ gcc/gimple-fold.cc                    | 20 +++++++++
+ gcc/testsuite/gcc.dg/field-merge-20.c | 64 +++++++++++++++++++++++++++
+ 2 files changed, 84 insertions(+)
+ create mode 100644 gcc/testsuite/gcc.dg/field-merge-20.c
+
+diff --git a/gcc/gimple-fold.cc b/gcc/gimple-fold.cc
+index a3987c4590ae..93ed8b3abb05 100644
+--- a/gcc/gimple-fold.cc
++++ b/gcc/gimple-fold.cc
+@@ -8270,6 +8270,16 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+ 	ll_and_mask = sign;
+       else
+ 	ll_and_mask &= sign;
++      if (l_xor)
++	{
++	  if (!lr_and_mask.get_precision ())
++	    lr_and_mask = sign;
++	  else
++	    lr_and_mask &= sign;
++	  if (l_const.get_precision ())
++	    l_const &= wide_int::from (lr_and_mask,
++				       l_const.get_precision (), UNSIGNED);
++	}
+     }
+ 
+   if (rsignbit)
+@@ -8279,6 +8289,16 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+ 	rl_and_mask = sign;
+       else
+ 	rl_and_mask &= sign;
++      if (r_xor)
++	{
++	  if (!rr_and_mask.get_precision ())
++	    rr_and_mask = sign;
++	  else
++	    rr_and_mask &= sign;
++	  if (r_const.get_precision ())
++	    r_const &= wide_int::from (rr_and_mask,
++				       r_const.get_precision (), UNSIGNED);
++	}
+     }
+ 
+   /* If either comparison code is not correct for our logical operation,
+diff --git a/gcc/testsuite/gcc.dg/field-merge-20.c b/gcc/testsuite/gcc.dg/field-merge-20.c
+new file mode 100644
+index 000000000000..44ac7fae50dc
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/field-merge-20.c
+@@ -0,0 +1,64 @@
++/* { dg-do run } */
++/* { dg-options "-O1" } */
++
++/* tree-optimization/118409 */
++
++/* Check that tests involving a sign bit of a storage unit are handled
++   correctly.  The compares are turned into xor tests by earlier passes, and
++   ifcombine has to propagate the sign bit mask to the right hand of the
++   compare extracted from the xor, otherwise we'll retain unwanted bits for the
++   compare.  */
++
++typedef struct {
++    int p : __CHAR_BIT__;
++    int d : 1;
++    int b : __CHAR_BIT__ - 2;
++    int e : 1;
++} g;
++
++g a = {.d = 1, .e = 1}, c = {.b = 1, .d = 1, .e = 1};
++
++__attribute__((noipa))
++int f1 ()
++{
++  if (a.d == c.d
++      && a.e == c.e)
++    return 0;
++  return -1;
++}
++
++__attribute__((noipa))
++int f2 ()
++{
++  if (a.d != c.d
++      || a.e != c.e)
++    return -1;
++  return 0;
++}
++
++__attribute__((noipa))
++int f3 ()
++{
++  if (c.d == a.d
++      && c.e == a.e)
++    return 0;
++  return -1;
++}
++
++__attribute__((noipa))
++int f4 ()
++{
++  if (c.d != a.d
++      || c.e != a.e)
++    return -1;
++  return 0;
++}
++
++int main() {
++  if (f1 () < 0
++      || f2 () < 0
++      || f3 () < 0
++      || f4 () < 0)
++    __builtin_abort();
++  return 0;
++}
+
+base-commit: 0e05b793fba2a9bea9f0fbb1f068679f5dadf514
+-- 
+2.48.0
+
diff --git a/15.0.0/gentoo/84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch b/15.0.0/gentoo/84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
new file mode 100644
index 0000000..e005c02
--- /dev/null
+++ b/15.0.0/gentoo/84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
@@ -0,0 +1,214 @@
+https://inbox.sourceware.org/gcc-patches/ora5bugmmi.fsf@lxoliva.fsfla.org/
+
+From 4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192 Mon Sep 17 00:00:00 2001
+Message-ID: <4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192.1736844127.git.sam@gentoo.org>
+From: Alexandre Oliva <oliva@adacore.com>
+Date: Mon, 13 Jan 2025 23:22:45 -0300
+Subject: [PATCH 1/2] check and extend constants to compare with bitfields
+ [PR118456]
+
+Add logic to check and extend constants compared with bitfields, so
+that fields are only compared with constants they could actually
+equal.  This involves making sure the signedness doesn't change
+between loads and conversions before shifts: we'd need to carry a lot
+more data to deal with all the possibilities.
+
+Regstrapped on x86_64-linux-gnu.  Ok to install?
+
+for  gcc/ChangeLog
+
+	PR tree-optimization/118456
+	* gimple-fold.cc (decode_field_reference): Punt if shifting
+	after changing signedness.
+	(fold_truth_andor_for_ifcombine): Check extension bits in
+	constants before clipping.
+
+for  gcc/testsuite/ChangeLog
+
+PR tree-optimization/118456
+	* gcc.dg/field-merge-21.c: New.
+	* gcc.dg/field-merge-22.c: New.
+---
+ gcc/gimple-fold.cc                    | 40 +++++++++++++++++++-
+ gcc/testsuite/gcc.dg/field-merge-21.c | 53 +++++++++++++++++++++++++++
+ gcc/testsuite/gcc.dg/field-merge-22.c | 31 ++++++++++++++++
+ 3 files changed, 122 insertions(+), 2 deletions(-)
+ create mode 100644 gcc/testsuite/gcc.dg/field-merge-21.c
+ create mode 100644 gcc/testsuite/gcc.dg/field-merge-22.c
+
+diff --git a/gcc/gimple-fold.cc b/gcc/gimple-fold.cc
+index 93ed8b3abb05..5b1fbe6db1df 100644
+--- a/gcc/gimple-fold.cc
++++ b/gcc/gimple-fold.cc
+@@ -7712,6 +7712,18 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+ 
+   if (shiftrt)
+     {
++      /* Punt if we're shifting by more than the loaded bitfield (after
++	 adjustment), or if there's a shift after a change of signedness, punt.
++	 When comparing this field with a constant, we'll check that the
++	 constant is a proper sign- or zero-extension (depending on signedness)
++	 of a value that would fit in the selected portion of the bitfield.  A
++	 shift after a change of signedness would make the extension
++	 non-uniform, and we can't deal with that (yet ???).  See
++	 gcc.dg/field-merge-22.c for a test that would go wrong.  */
++      if (*pbitsize <= shiftrt
++	  || (convert_before_shift
++	      && outer_type && unsignedp != TYPE_UNSIGNED (outer_type)))
++	return NULL_TREE;
+       if (!*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
+ 	*pbitpos += shiftrt;
+       *pbitsize -= shiftrt;
+@@ -8512,13 +8524,25 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+      and bit position.  */
+   if (l_const.get_precision ())
+     {
++      /* Before clipping upper bits of the right-hand operand of the compare,
++	 check that they're sign or zero extensions, depending on how the
++	 left-hand operand would be extended.  */
++      bool l_non_ext_bits = false;
++      if (ll_bitsize < lr_bitsize)
++	{
++	  wide_int zext = wi::zext (l_const, ll_bitsize);
++	  if ((ll_unsignedp ? zext : wi::sext (l_const, ll_bitsize)) == l_const)
++	    l_const = zext;
++	  else
++	    l_non_ext_bits = true;
++	}
+       /* We're doing bitwise equality tests, so don't bother with sign
+ 	 extensions.  */
+       l_const = wide_int::from (l_const, lnprec, UNSIGNED);
+       if (ll_and_mask.get_precision ())
+ 	l_const &= wide_int::from (ll_and_mask, lnprec, UNSIGNED);
+       l_const <<= xll_bitpos;
+-      if ((l_const & ~ll_mask) != 0)
++      if (l_non_ext_bits || (l_const & ~ll_mask) != 0)
+ 	{
+ 	  warning_at (lloc, OPT_Wtautological_compare,
+ 		      "comparison is always %d", wanted_code == NE_EXPR);
+@@ -8530,11 +8554,23 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+ 	 again.  */
+       gcc_checking_assert (r_const.get_precision ());
+ 
++      /* Before clipping upper bits of the right-hand operand of the compare,
++	 check that they're sign or zero extensions, depending on how the
++	 left-hand operand would be extended.  */
++      bool r_non_ext_bits = false;
++      if (rl_bitsize < rr_bitsize)
++	{
++	  wide_int zext = wi::zext (r_const, rl_bitsize);
++	  if ((rl_unsignedp ? zext : wi::sext (r_const, rl_bitsize)) == r_const)
++	    r_const = zext;
++	  else
++	    r_non_ext_bits = true;
++	}
+       r_const = wide_int::from (r_const, lnprec, UNSIGNED);
+       if (rl_and_mask.get_precision ())
+ 	r_const &= wide_int::from (rl_and_mask, lnprec, UNSIGNED);
+       r_const <<= xrl_bitpos;
+-      if ((r_const & ~rl_mask) != 0)
++      if (r_non_ext_bits || (r_const & ~rl_mask) != 0)
+ 	{
+ 	  warning_at (rloc, OPT_Wtautological_compare,
+ 		      "comparison is always %d", wanted_code == NE_EXPR);
+diff --git a/gcc/testsuite/gcc.dg/field-merge-21.c b/gcc/testsuite/gcc.dg/field-merge-21.c
+new file mode 100644
+index 000000000000..042b2123eb63
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/field-merge-21.c
+@@ -0,0 +1,53 @@
++/* { dg-do run } */
++/* { dg-options "-O2" } */
++
++/* PR tree-optimization/118456 */
++/* Check that shifted fields compared with a constants compare correctly even
++   if the constant contains sign-extension bits not present in the bit
++   range.  */
++
++struct S { unsigned long long o; unsigned short a, b; } s;
++
++__attribute__((noipa)) int
++foo (void)
++{
++  return ((unsigned char) s.a) >> 3 == 17 && ((signed char) s.b) >> 2 == -27;
++}
++
++__attribute__((noipa)) int
++bar (void)
++{
++  return ((unsigned char) s.a) >> 3 == 17 && ((signed char) s.b) >> 2 == -91;
++}
++
++__attribute__((noipa)) int
++bars (void)
++{
++  return ((unsigned char) s.a) >> 3 == 17 && ((signed char) s.b) >> 2 == 37;
++}
++
++__attribute__((noipa)) int
++baz (void)
++{
++  return ((unsigned char) s.a) >> 3 == 49 && ((signed char) s.b) >> 2 == -27;
++}
++
++__attribute__((noipa)) int
++bazs (void)
++{
++  return ((unsigned char) s.a) >> 3 == (unsigned char) -15 && ((signed char) s.b) >> 2 == -27;
++}
++
++int
++main ()
++{
++  s.a = 17 << 3;
++  s.b = (unsigned short)(-27u << 2);
++  if (foo () != 1
++      || bar () != 0
++      || bars () != 0
++      || baz () != 0
++      || bazs () != 0)
++    __builtin_abort ();
++  return 0;
++}
+diff --git a/gcc/testsuite/gcc.dg/field-merge-22.c b/gcc/testsuite/gcc.dg/field-merge-22.c
+new file mode 100644
+index 000000000000..45b29c0bccaf
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/field-merge-22.c
+@@ -0,0 +1,31 @@
++/* { dg-do run } */
++/* { dg-options "-O2" } */
++
++/* PR tree-optimization/118456 */
++/* Check that compares with constants take into account sign/zero extension of
++   both the bitfield and of the shifting type.  */
++
++#define shift (__CHAR_BIT__ - 4)
++
++struct S {
++  signed char a : shift + 2;
++  signed char b : shift + 2;
++  short ignore[0];
++} s;
++
++__attribute__((noipa)) int
++foo (void)
++{
++  return ((unsigned char) s.a) >> shift == 15
++    && ((unsigned char) s.b) >> shift == 0;
++}
++
++int
++main ()
++{
++  s.a = -1;
++  s.b = 1;
++  if (foo () != 1)
++    __builtin_abort ();
++  return 0;
++}
+
+base-commit: 31c3c1a83fd885b4687c9f6f7acd68af76d758d3
+-- 
+2.48.0
+
diff --git a/15.0.0/gentoo/85_all_PR118456-robustify-decode_field_reference.patch b/15.0.0/gentoo/85_all_PR118456-robustify-decode_field_reference.patch
new file mode 100644
index 0000000..065c958
--- /dev/null
+++ b/15.0.0/gentoo/85_all_PR118456-robustify-decode_field_reference.patch
@@ -0,0 +1,354 @@
+https://inbox.sourceware.org/gcc-patches/or1px6gf6r.fsf@lxoliva.fsfla.org/
+
+From e3a5a707fd88522a73d05841970fa2465e991eaa Mon Sep 17 00:00:00 2001
+Message-ID: <e3a5a707fd88522a73d05841970fa2465e991eaa.1736844127.git.sam@gentoo.org>
+In-Reply-To: <4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192.1736844127.git.sam@gentoo.org>
+References: <4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192.1736844127.git.sam@gentoo.org>
+From: Alexandre Oliva <oliva@adacore.com>
+Date: Tue, 14 Jan 2025 02:03:24 -0300
+Subject: [PATCH 2/2] robustify decode_field_reference
+
+Arrange for decode_field_reference to use local variables throughout,
+to modify the out parms only when we're about to return non-NULL, and
+to drop the unused case of NULL pand_mask, that had a latent failure
+to detect signbit masking.
+
+Regstrapped on x86_64-linux-gnu along with the PR118456 patch.
+Ok to install?
+
+for  gcc/ChangeLog
+
+* gimple-fold.cc (decode_field_reference): Rebustify to set
+	out parms only when returning non-NULL.
+	(fold_truth_andor_for_ifcombine): Bail if
+	decode_field_reference returns NULL.  Add complementary assert
+	on r_const's not being set when l_const isn't.
+---
+ gcc/gimple-fold.cc | 155 +++++++++++++++++++++++----------------------
+ 1 file changed, 80 insertions(+), 75 deletions(-)
+
+diff --git a/gcc/gimple-fold.cc b/gcc/gimple-fold.cc
+index 5b1fbe6db1df..3c971a29ef04 100644
+--- a/gcc/gimple-fold.cc
++++ b/gcc/gimple-fold.cc
+@@ -7510,18 +7510,17 @@ gimple_binop_def_p (enum tree_code code, tree t, tree op[2])
+    *PREVERSEP is set to the storage order of the field.
+ 
+    *PAND_MASK is set to the mask found in a BIT_AND_EXPR, if any.  If
+-   PAND_MASK *is NULL, BIT_AND_EXPR is not recognized.  If *PAND_MASK
+-   is initially set to a mask with nonzero precision, that mask is
++   *PAND_MASK is initially set to a mask with nonzero precision, that mask is
+    combined with the found mask, or adjusted in precision to match.
+ 
+    *PSIGNBIT is set to TRUE if, before clipping to *PBITSIZE, the mask
+    encompassed bits that corresponded to extensions of the sign bit.
+ 
+-   *XOR_P is to be FALSE if EXP might be a XOR used in a compare, in which
+-   case, if XOR_CMP_OP is a zero constant, it will be overridden with *PEXP,
+-   *XOR_P will be set to TRUE, *XOR_PAND_MASK will be copied from *PAND_MASK,
+-   and the left-hand operand of the XOR will be decoded.  If *XOR_P is TRUE,
+-   XOR_CMP_OP and XOR_PAND_MASK are supposed to be NULL, and then the
++   *PXORP is to be FALSE if EXP might be a XOR used in a compare, in which
++   case, if PXOR_CMP_OP is a zero constant, it will be overridden with *PEXP,
++   *PXORP will be set to TRUE, *PXOR_AND_MASK will be copied from *PAND_MASK,
++   and the left-hand operand of the XOR will be decoded.  If *PXORP is TRUE,
++   PXOR_CMP_OP and PXOR_AND_MASK are supposed to be NULL, and then the
+    right-hand operand of the XOR will be decoded.
+ 
+    *LOAD is set to the load stmt of the innermost reference, if any,
+@@ -7538,8 +7537,8 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+ 			HOST_WIDE_INT *pbitpos,
+ 			bool *punsignedp, bool *preversep, bool *pvolatilep,
+ 			wide_int *pand_mask, bool *psignbit,
+-			bool *xor_p, tree *xor_cmp_op, wide_int *xor_pand_mask,
+-			gimple **load, location_t loc[4])
++			bool *pxorp, tree *pxor_cmp_op, wide_int *pxor_and_mask,
++			gimple **pload, location_t loc[4])
+ {
+   tree exp = *pexp;
+   tree outer_type = 0;
+@@ -7549,9 +7548,11 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+   tree res_ops[2];
+   machine_mode mode;
+   bool convert_before_shift = false;
+-
+-  *load = NULL;
+-  *psignbit = false;
++  bool signbit = false;
++  bool xorp = false;
++  tree xor_cmp_op;
++  wide_int xor_and_mask;
++  gimple *load = NULL;
+ 
+   /* All the optimizations using this function assume integer fields.
+      There are problems with FP fields since the type_for_size call
+@@ -7576,7 +7577,7 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+ 
+   /* Recognize and save a masking operation.  Combine it with an
+      incoming mask.  */
+-  if (pand_mask && gimple_binop_def_p (BIT_AND_EXPR, exp, res_ops)
++  if (gimple_binop_def_p (BIT_AND_EXPR, exp, res_ops)
+       && TREE_CODE (res_ops[1]) == INTEGER_CST)
+     {
+       loc[1] = gimple_location (SSA_NAME_DEF_STMT (exp));
+@@ -7596,29 +7597,29 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+ 	    and_mask &= wide_int::from (*pand_mask, prec_op, UNSIGNED);
+ 	}
+     }
+-  else if (pand_mask)
++  else
+     and_mask = *pand_mask;
+ 
+   /* Turn (a ^ b) [!]= 0 into a [!]= b.  */
+-  if (xor_p && gimple_binop_def_p (BIT_XOR_EXPR, exp, res_ops))
++  if (pxorp && gimple_binop_def_p (BIT_XOR_EXPR, exp, res_ops))
+     {
+       /* No location recorded for this one, it's entirely subsumed by the
+ 	 compare.  */
+-      if (*xor_p)
++      if (*pxorp)
+ 	{
+ 	  exp = res_ops[1];
+-	  gcc_checking_assert (!xor_cmp_op && !xor_pand_mask);
++	  gcc_checking_assert (!pxor_cmp_op && !pxor_and_mask);
+ 	}
+-      else if (!xor_cmp_op)
++      else if (!pxor_cmp_op)
+ 	/* Not much we can do when xor appears in the right-hand compare
+ 	   operand.  */
+ 	return NULL_TREE;
+-      else if (integer_zerop (*xor_cmp_op))
++      else if (integer_zerop (*pxor_cmp_op))
+ 	{
+-	  *xor_p = true;
++	  xorp = true;
+ 	  exp = res_ops[0];
+-	  *xor_cmp_op = *pexp;
+-	  *xor_pand_mask = *pand_mask;
++	  xor_cmp_op = *pexp;
++	  xor_and_mask = *pand_mask;
+ 	}
+     }
+ 
+@@ -7646,12 +7647,12 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+   /* Yet another chance to drop conversions.  This one is allowed to
+      match a converting load, subsuming the load identification block
+      below.  */
+-  if (!outer_type && gimple_convert_def_p (exp, res_ops, load))
++  if (!outer_type && gimple_convert_def_p (exp, res_ops, &load))
+     {
+       outer_type = TREE_TYPE (exp);
+       loc[0] = gimple_location (SSA_NAME_DEF_STMT (exp));
+-      if (*load)
+-	loc[3] = gimple_location (*load);
++      if (load)
++	loc[3] = gimple_location (load);
+       exp = res_ops[0];
+       /* This looks backwards, but we're going back the def chain, so if we
+ 	 find the conversion here, after finding a shift, that's because the
+@@ -7662,14 +7663,13 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+     }
+ 
+   /* Identify the load, if there is one.  */
+-  if (!(*load) && TREE_CODE (exp) == SSA_NAME
+-      && !SSA_NAME_IS_DEFAULT_DEF (exp))
++  if (!load && TREE_CODE (exp) == SSA_NAME && !SSA_NAME_IS_DEFAULT_DEF (exp))
+     {
+       gimple *def = SSA_NAME_DEF_STMT (exp);
+       if (gimple_assign_load_p (def))
+ 	{
+ 	  loc[3] = gimple_location (def);
+-	  *load = def;
++	  load = def;
+ 	  exp = gimple_assign_rhs1 (def);
+ 	}
+     }
+@@ -7694,20 +7694,14 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+ 	  && !type_has_mode_precision_p (TREE_TYPE (inner))))
+     return NULL_TREE;
+ 
+-  *pbitsize = bs;
+-  *pbitpos = bp;
+-  *punsignedp = unsignedp;
+-  *preversep = reversep;
+-  *pvolatilep = volatilep;
+-
+   /* Adjust shifts...  */
+   if (convert_before_shift
+-      && outer_type && *pbitsize > TYPE_PRECISION (outer_type))
++      && outer_type && bs > TYPE_PRECISION (outer_type))
+     {
+-      HOST_WIDE_INT excess = *pbitsize - TYPE_PRECISION (outer_type);
+-      if (*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
+-	*pbitpos += excess;
+-      *pbitsize -= excess;
++      HOST_WIDE_INT excess = bs - TYPE_PRECISION (outer_type);
++      if (reversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
++	bp += excess;
++      bs -= excess;
+     }
+ 
+   if (shiftrt)
+@@ -7720,49 +7714,57 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
+ 	 shift after a change of signedness would make the extension
+ 	 non-uniform, and we can't deal with that (yet ???).  See
+ 	 gcc.dg/field-merge-22.c for a test that would go wrong.  */
+-      if (*pbitsize <= shiftrt
++      if (bs <= shiftrt
+ 	  || (convert_before_shift
+ 	      && outer_type && unsignedp != TYPE_UNSIGNED (outer_type)))
+ 	return NULL_TREE;
+-      if (!*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
+-	*pbitpos += shiftrt;
+-      *pbitsize -= shiftrt;
++      if (!reversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
++	bp += shiftrt;
++      bs -= shiftrt;
+     }
+ 
+   /* ... and bit position.  */
+   if (!convert_before_shift
+-      && outer_type && *pbitsize > TYPE_PRECISION (outer_type))
++      && outer_type && bs > TYPE_PRECISION (outer_type))
+     {
+-      HOST_WIDE_INT excess = *pbitsize - TYPE_PRECISION (outer_type);
+-      if (*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
+-	*pbitpos += excess;
+-      *pbitsize -= excess;
++      HOST_WIDE_INT excess = bs - TYPE_PRECISION (outer_type);
++      if (reversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
++	bp += excess;
++      bs -= excess;
+     }
+ 
+-  *pexp = exp;
+-
+   /* If the number of bits in the reference is the same as the bitsize of
+      the outer type, then the outer type gives the signedness. Otherwise
+      (in case of a small bitfield) the signedness is unchanged.  */
+-  if (outer_type && *pbitsize == TYPE_PRECISION (outer_type))
+-    *punsignedp = TYPE_UNSIGNED (outer_type);
++  if (outer_type && bs == TYPE_PRECISION (outer_type))
++    unsignedp = TYPE_UNSIGNED (outer_type);
+ 
+-  if (pand_mask)
++  /* Make the mask the expected width.  */
++  if (and_mask.get_precision () != 0)
+     {
+-      /* Make the mask the expected width.  */
+-      if (and_mask.get_precision () != 0)
+-	{
+-	  /* If the AND_MASK encompasses bits that would be extensions of
+-	     the sign bit, set *PSIGNBIT.  */
+-	  if (!unsignedp
+-	      && and_mask.get_precision () > *pbitsize
+-	      && (and_mask
+-		  & wi::mask (*pbitsize, true, and_mask.get_precision ())) != 0)
+-	    *psignbit = true;
+-	  and_mask = wide_int::from (and_mask, *pbitsize, UNSIGNED);
+-	}
++      /* If the AND_MASK encompasses bits that would be extensions of
++	 the sign bit, set SIGNBIT.  */
++      if (!unsignedp
++	  && and_mask.get_precision () > bs
++	  && (and_mask & wi::mask (bs, true, and_mask.get_precision ())) != 0)
++	signbit = true;
++      and_mask = wide_int::from (and_mask, bs, UNSIGNED);
++    }
+ 
+-      *pand_mask = and_mask;
++  *pexp = exp;
++  *pload = load;
++  *pbitsize = bs;
++  *pbitpos = bp;
++  *punsignedp = unsignedp;
++  *preversep = reversep;
++  *pvolatilep = volatilep;
++  *psignbit = signbit;
++  *pand_mask = and_mask;
++  if (xorp)
++    {
++      *pxorp = xorp;
++      *pxor_cmp_op = xor_cmp_op;
++      *pxor_and_mask = xor_and_mask;
+     }
+ 
+   return inner;
+@@ -8168,19 +8170,27 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+ 				     &ll_and_mask, &ll_signbit,
+ 				     &l_xor, &lr_arg, &lr_and_mask,
+ 				     &ll_load, ll_loc);
++  if (!ll_inner)
++    return 0;
+   lr_inner = decode_field_reference (&lr_arg, &lr_bitsize, &lr_bitpos,
+ 				     &lr_unsignedp, &lr_reversep, &volatilep,
+ 				     &lr_and_mask, &lr_signbit, &l_xor, 0, 0,
+ 				     &lr_load, lr_loc);
++  if (!lr_inner)
++    return 0;
+   rl_inner = decode_field_reference (&rl_arg, &rl_bitsize, &rl_bitpos,
+ 				     &rl_unsignedp, &rl_reversep, &volatilep,
+ 				     &rl_and_mask, &rl_signbit,
+ 				     &r_xor, &rr_arg, &rr_and_mask,
+ 				     &rl_load, rl_loc);
++  if (!rl_inner)
++    return 0;
+   rr_inner = decode_field_reference (&rr_arg, &rr_bitsize, &rr_bitpos,
+ 				     &rr_unsignedp, &rr_reversep, &volatilep,
+ 				     &rr_and_mask, &rr_signbit, &r_xor, 0, 0,
+ 				     &rr_load, rr_loc);
++  if (!rr_inner)
++    return 0;
+ 
+   /* It must be true that the inner operation on the lhs of each
+      comparison must be the same if we are to be able to do anything.
+@@ -8188,16 +8198,13 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+      the rhs's.  If one is a load and the other isn't, we have to be
+      conservative and avoid the optimization, otherwise we could get
+      SRAed fields wrong.  */
+-  if (volatilep
+-      || ll_reversep != rl_reversep
+-      || ll_inner == 0 || rl_inner == 0)
++  if (volatilep || ll_reversep != rl_reversep)
+     return 0;
+ 
+   if (! operand_equal_p (ll_inner, rl_inner, 0))
+     {
+       /* Try swapping the operands.  */
+       if (ll_reversep != rr_reversep
+-	  || !rr_inner
+ 	  || !operand_equal_p (ll_inner, rr_inner, 0))
+ 	return 0;
+ 
+@@ -8266,7 +8273,6 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+       lr_reversep = ll_reversep;
+     }
+   else if (lr_reversep != rr_reversep
+-	   || lr_inner == 0 || rr_inner == 0
+ 	   || ! operand_equal_p (lr_inner, rr_inner, 0)
+ 	   || ((lr_load && rr_load)
+ 	       ? gimple_vuse (lr_load) != gimple_vuse (rr_load)
+@@ -8520,6 +8526,9 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+   else
+     rl_mask = wi::shifted_mask (xrl_bitpos, rl_bitsize, false, lnprec);
+ 
++  /* When we set l_const, we also set r_const.  */
++  gcc_checking_assert (!l_const.get_precision () == !r_const.get_precision ());
++
+   /* Adjust right-hand constants in both original comparisons to match width
+      and bit position.  */
+   if (l_const.get_precision ())
+@@ -8550,10 +8559,6 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
+ 	  return constant_boolean_node (wanted_code == NE_EXPR, truth_type);
+ 	}
+ 
+-      /* When we set l_const, we also set r_const, so we need not test it
+-	 again.  */
+-      gcc_checking_assert (r_const.get_precision ());
+-
+       /* Before clipping upper bits of the right-hand operand of the compare,
+ 	 check that they're sign or zero extensions, depending on how the
+ 	 left-hand operand would be extended.  */
+-- 
+2.48.0
+
diff --git a/15.0.0/gentoo/86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch b/15.0.0/gentoo/86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
new file mode 100644
index 0000000..ce0b338
--- /dev/null
+++ b/15.0.0/gentoo/86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
@@ -0,0 +1,87 @@
+From a1a14ce3c39c25fecf052ffde063fc0ecfc2ffa3 Mon Sep 17 00:00:00 2001
+Message-ID: <a1a14ce3c39c25fecf052ffde063fc0ecfc2ffa3.1736867096.git.sam@gentoo.org>
+From: Richard Sandiford <richard.sandiford@arm.com>
+Date: Mon, 13 Jan 2025 19:37:12 +0000
+Subject: [PATCH] Fix build for STORE_FLAG_VALUE<0 targets [PR118418]
+
+In g:06c4cf398947b53b4bfc65752f9f879bb2d07924 I mishandled signed
+comparisons of comparison results on STORE_FLAG_VALUE < 0 targets
+(despite specifically referencing STORE_FLAG_VALUE in the commit
+message).  There, (lt TRUE FALSE) is true, although (ltu FALSE TRUE)
+still holds.
+
+Things get messy with vector modes, and since those weren't the focus
+of the original commit, it seemed better to punt on them for now.
+However, punting means that this optimisation no longer feels like
+a natural tail-call operation.  The patch therefore converts
+"return simplify..." to the usual call-and-conditional-return pattern.
+
+gcc/
+	PR target/118418
+	* simplify-rtx.cc (simplify_context::simplify_relational_operation_1):
+	Take STORE_FLAG_VALUE into account when handling signed comparisons
+	of comparison results.
+---
+ gcc/simplify-rtx.cc | 39 ++++++++++++++++++++++++---------------
+ 1 file changed, 24 insertions(+), 15 deletions(-)
+
+diff --git a/gcc/simplify-rtx.cc b/gcc/simplify-rtx.cc
+index 71c5d3c1b1b8..dda8fc689e79 100644
+--- a/gcc/simplify-rtx.cc
++++ b/gcc/simplify-rtx.cc
+@@ -6434,7 +6434,7 @@ simplify_context::simplify_relational_operation_1 (rtx_code code,
+ 	return simplify_gen_binary (AND, mode, XEXP (tmp, 0), const1_rtx);
+     }
+ 
+-  /* For two booleans A and B:
++  /* For two unsigned booleans A and B:
+ 
+      A >  B == ~B & A
+      A >= B == ~B | A
+@@ -6443,20 +6443,29 @@ simplify_context::simplify_relational_operation_1 (rtx_code code,
+      A == B == ~A ^ B (== ~B ^ A)
+      A != B ==  A ^ B
+ 
+-     simplify_logical_relational_operation checks whether A and B
+-     are booleans.  */
+-  if (code == GTU || code == GT)
+-    return simplify_logical_relational_operation (AND, mode, op1, op0, true);
+-  if (code == GEU || code == GE)
+-    return simplify_logical_relational_operation (IOR, mode, op1, op0, true);
+-  if (code == LTU || code == LT)
+-    return simplify_logical_relational_operation (AND, mode, op0, op1, true);
+-  if (code == LEU || code == LE)
+-    return simplify_logical_relational_operation (IOR, mode, op0, op1, true);
+-  if (code == EQ)
+-    return simplify_logical_relational_operation (XOR, mode, op0, op1, true);
+-  if (code == NE)
+-    return simplify_logical_relational_operation (XOR, mode, op0, op1);
++     For signed comparisons, we have to take STORE_FLAG_VALUE into account,
++     with the rules above applying for positive STORE_FLAG_VALUE and with
++     the relations reversed for negative STORE_FLAG_VALUE.  */
++  if (is_a<scalar_int_mode> (cmp_mode)
++      && COMPARISON_P (op0)
++      && COMPARISON_P (op1))
++    {
++      rtx t = NULL_RTX;
++      if (code == GTU || code == (STORE_FLAG_VALUE > 0 ? GT : LT))
++	t = simplify_logical_relational_operation (AND, mode, op1, op0, true);
++      else if (code == GEU || code == (STORE_FLAG_VALUE > 0 ? GE : LE))
++	t = simplify_logical_relational_operation (IOR, mode, op1, op0, true);
++      else if (code == LTU || code == (STORE_FLAG_VALUE > 0 ? LT : GT))
++	t = simplify_logical_relational_operation (AND, mode, op0, op1, true);
++      else if (code == LEU || code == (STORE_FLAG_VALUE > 0 ? LE : GE))
++	t = simplify_logical_relational_operation (IOR, mode, op0, op1, true);
++      else if (code == EQ)
++	t = simplify_logical_relational_operation (XOR, mode, op0, op1, true);
++      else if (code == NE)
++	t = simplify_logical_relational_operation (XOR, mode, op0, op1);
++      if (t)
++	return t;
++    }
+ 
+   return NULL_RTX;
+ }
+-- 
+2.48.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index a3e5131..4650c20 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,8 +1,6 @@
-41	????
+41	16 January 2025
 
-	- 84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
-	- 85_all_PR118456-robustify-decode_field_reference.patch
-	- 86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
+	+ 82_all_PR118409-ifcombine.patch
 
 40	14 January 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-16 23:11 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-16 23:11 UTC (permalink / raw
  To: gentoo-commits
commit:     7b1b42ebd4b59fadb62692e1821d4a14123c85e7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jan 16 23:09:29 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jan 16 23:10:59 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=7b1b42eb
15.0.0: drop patches merged upstream
This reverts commit e42dbea5f6e2a59e7a2aafe1f406ddf697a2658e.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/82_all_PR118409-ifcombine.patch      | 154 ---------
 ...xtend-constants-to-compare-with-bitfields.patch | 214 -------------
 ...PR118456-robustify-decode_field_reference.patch | 354 ---------------------
 ...-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch |  87 -----
 15.0.0/gentoo/README.history                       |   6 +
 5 files changed, 6 insertions(+), 809 deletions(-)
diff --git a/15.0.0/gentoo/82_all_PR118409-ifcombine.patch b/15.0.0/gentoo/82_all_PR118409-ifcombine.patch
deleted file mode 100644
index 6362cd1..0000000
--- a/15.0.0/gentoo/82_all_PR118409-ifcombine.patch
+++ /dev/null
@@ -1,154 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/ored17gz9x.fsf@lxoliva.fsfla.org/
-
-From bfb791ad941348a0bb854b770f2294424528bc40 Mon Sep 17 00:00:00 2001
-Message-ID: <bfb791ad941348a0bb854b770f2294424528bc40.1736739564.git.sam@gentoo.org>
-From: Alexandre Oliva <oliva@adacore.com>
-Date: Mon, 13 Jan 2025 00:37:14 -0300
-Subject: [PATCH] propagate signbit mask to XOR right-hand operand
-
-If a single-bit bitfield takes up the sign bit of a storage unit,
-comparing the corresponding bitfield between two objects loads the
-storage units, XORs them, converts the result to signed char, and
-compares it with zero: ((signed char)(a.<byte> ^ c.<byte>) >= 0).
-
-fold_truth_andor_for_ifcombine recognizes the compare with zero as a
-sign bit test, then it decomposes the XOR into an equality test.
-
-The problem is that, after this decomposition, that figures out the
-width of the accessed fields, we apply the sign bit mask to the
-left-hand operand of the compare, but we failed to also apply it to
-the right-hand operand when both were taken from the same XOR.
-
-This patch fixes that.
-
-Regstrapped on x86_64-linux-gnu.  Ok to install?
-
-for  gcc/ChangeLog
-
-	PR tree-optimization/118409
-	* gimple-fold.cc (fold_truth_andor_for_ifcombine): Apply the
-	signbit mask to the right-hand XOR operand too.
-
-for  gcc/testsuite/ChangeLog
-
-PR tree-optimization/118409
-	* gcc.dg/field-merge-20.c: New.
----
- gcc/gimple-fold.cc                    | 20 +++++++++
- gcc/testsuite/gcc.dg/field-merge-20.c | 64 +++++++++++++++++++++++++++
- 2 files changed, 84 insertions(+)
- create mode 100644 gcc/testsuite/gcc.dg/field-merge-20.c
-
-diff --git a/gcc/gimple-fold.cc b/gcc/gimple-fold.cc
-index a3987c4590ae..93ed8b3abb05 100644
---- a/gcc/gimple-fold.cc
-+++ b/gcc/gimple-fold.cc
-@@ -8270,6 +8270,16 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
- 	ll_and_mask = sign;
-       else
- 	ll_and_mask &= sign;
-+      if (l_xor)
-+	{
-+	  if (!lr_and_mask.get_precision ())
-+	    lr_and_mask = sign;
-+	  else
-+	    lr_and_mask &= sign;
-+	  if (l_const.get_precision ())
-+	    l_const &= wide_int::from (lr_and_mask,
-+				       l_const.get_precision (), UNSIGNED);
-+	}
-     }
- 
-   if (rsignbit)
-@@ -8279,6 +8289,16 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
- 	rl_and_mask = sign;
-       else
- 	rl_and_mask &= sign;
-+      if (r_xor)
-+	{
-+	  if (!rr_and_mask.get_precision ())
-+	    rr_and_mask = sign;
-+	  else
-+	    rr_and_mask &= sign;
-+	  if (r_const.get_precision ())
-+	    r_const &= wide_int::from (rr_and_mask,
-+				       r_const.get_precision (), UNSIGNED);
-+	}
-     }
- 
-   /* If either comparison code is not correct for our logical operation,
-diff --git a/gcc/testsuite/gcc.dg/field-merge-20.c b/gcc/testsuite/gcc.dg/field-merge-20.c
-new file mode 100644
-index 000000000000..44ac7fae50dc
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/field-merge-20.c
-@@ -0,0 +1,64 @@
-+/* { dg-do run } */
-+/* { dg-options "-O1" } */
-+
-+/* tree-optimization/118409 */
-+
-+/* Check that tests involving a sign bit of a storage unit are handled
-+   correctly.  The compares are turned into xor tests by earlier passes, and
-+   ifcombine has to propagate the sign bit mask to the right hand of the
-+   compare extracted from the xor, otherwise we'll retain unwanted bits for the
-+   compare.  */
-+
-+typedef struct {
-+    int p : __CHAR_BIT__;
-+    int d : 1;
-+    int b : __CHAR_BIT__ - 2;
-+    int e : 1;
-+} g;
-+
-+g a = {.d = 1, .e = 1}, c = {.b = 1, .d = 1, .e = 1};
-+
-+__attribute__((noipa))
-+int f1 ()
-+{
-+  if (a.d == c.d
-+      && a.e == c.e)
-+    return 0;
-+  return -1;
-+}
-+
-+__attribute__((noipa))
-+int f2 ()
-+{
-+  if (a.d != c.d
-+      || a.e != c.e)
-+    return -1;
-+  return 0;
-+}
-+
-+__attribute__((noipa))
-+int f3 ()
-+{
-+  if (c.d == a.d
-+      && c.e == a.e)
-+    return 0;
-+  return -1;
-+}
-+
-+__attribute__((noipa))
-+int f4 ()
-+{
-+  if (c.d != a.d
-+      || c.e != a.e)
-+    return -1;
-+  return 0;
-+}
-+
-+int main() {
-+  if (f1 () < 0
-+      || f2 () < 0
-+      || f3 () < 0
-+      || f4 () < 0)
-+    __builtin_abort();
-+  return 0;
-+}
-
-base-commit: 0e05b793fba2a9bea9f0fbb1f068679f5dadf514
--- 
-2.48.0
-
diff --git a/15.0.0/gentoo/84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch b/15.0.0/gentoo/84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
deleted file mode 100644
index e005c02..0000000
--- a/15.0.0/gentoo/84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
+++ /dev/null
@@ -1,214 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/ora5bugmmi.fsf@lxoliva.fsfla.org/
-
-From 4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192 Mon Sep 17 00:00:00 2001
-Message-ID: <4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192.1736844127.git.sam@gentoo.org>
-From: Alexandre Oliva <oliva@adacore.com>
-Date: Mon, 13 Jan 2025 23:22:45 -0300
-Subject: [PATCH 1/2] check and extend constants to compare with bitfields
- [PR118456]
-
-Add logic to check and extend constants compared with bitfields, so
-that fields are only compared with constants they could actually
-equal.  This involves making sure the signedness doesn't change
-between loads and conversions before shifts: we'd need to carry a lot
-more data to deal with all the possibilities.
-
-Regstrapped on x86_64-linux-gnu.  Ok to install?
-
-for  gcc/ChangeLog
-
-	PR tree-optimization/118456
-	* gimple-fold.cc (decode_field_reference): Punt if shifting
-	after changing signedness.
-	(fold_truth_andor_for_ifcombine): Check extension bits in
-	constants before clipping.
-
-for  gcc/testsuite/ChangeLog
-
-PR tree-optimization/118456
-	* gcc.dg/field-merge-21.c: New.
-	* gcc.dg/field-merge-22.c: New.
----
- gcc/gimple-fold.cc                    | 40 +++++++++++++++++++-
- gcc/testsuite/gcc.dg/field-merge-21.c | 53 +++++++++++++++++++++++++++
- gcc/testsuite/gcc.dg/field-merge-22.c | 31 ++++++++++++++++
- 3 files changed, 122 insertions(+), 2 deletions(-)
- create mode 100644 gcc/testsuite/gcc.dg/field-merge-21.c
- create mode 100644 gcc/testsuite/gcc.dg/field-merge-22.c
-
-diff --git a/gcc/gimple-fold.cc b/gcc/gimple-fold.cc
-index 93ed8b3abb05..5b1fbe6db1df 100644
---- a/gcc/gimple-fold.cc
-+++ b/gcc/gimple-fold.cc
-@@ -7712,6 +7712,18 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
- 
-   if (shiftrt)
-     {
-+      /* Punt if we're shifting by more than the loaded bitfield (after
-+	 adjustment), or if there's a shift after a change of signedness, punt.
-+	 When comparing this field with a constant, we'll check that the
-+	 constant is a proper sign- or zero-extension (depending on signedness)
-+	 of a value that would fit in the selected portion of the bitfield.  A
-+	 shift after a change of signedness would make the extension
-+	 non-uniform, and we can't deal with that (yet ???).  See
-+	 gcc.dg/field-merge-22.c for a test that would go wrong.  */
-+      if (*pbitsize <= shiftrt
-+	  || (convert_before_shift
-+	      && outer_type && unsignedp != TYPE_UNSIGNED (outer_type)))
-+	return NULL_TREE;
-       if (!*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
- 	*pbitpos += shiftrt;
-       *pbitsize -= shiftrt;
-@@ -8512,13 +8524,25 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
-      and bit position.  */
-   if (l_const.get_precision ())
-     {
-+      /* Before clipping upper bits of the right-hand operand of the compare,
-+	 check that they're sign or zero extensions, depending on how the
-+	 left-hand operand would be extended.  */
-+      bool l_non_ext_bits = false;
-+      if (ll_bitsize < lr_bitsize)
-+	{
-+	  wide_int zext = wi::zext (l_const, ll_bitsize);
-+	  if ((ll_unsignedp ? zext : wi::sext (l_const, ll_bitsize)) == l_const)
-+	    l_const = zext;
-+	  else
-+	    l_non_ext_bits = true;
-+	}
-       /* We're doing bitwise equality tests, so don't bother with sign
- 	 extensions.  */
-       l_const = wide_int::from (l_const, lnprec, UNSIGNED);
-       if (ll_and_mask.get_precision ())
- 	l_const &= wide_int::from (ll_and_mask, lnprec, UNSIGNED);
-       l_const <<= xll_bitpos;
--      if ((l_const & ~ll_mask) != 0)
-+      if (l_non_ext_bits || (l_const & ~ll_mask) != 0)
- 	{
- 	  warning_at (lloc, OPT_Wtautological_compare,
- 		      "comparison is always %d", wanted_code == NE_EXPR);
-@@ -8530,11 +8554,23 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
- 	 again.  */
-       gcc_checking_assert (r_const.get_precision ());
- 
-+      /* Before clipping upper bits of the right-hand operand of the compare,
-+	 check that they're sign or zero extensions, depending on how the
-+	 left-hand operand would be extended.  */
-+      bool r_non_ext_bits = false;
-+      if (rl_bitsize < rr_bitsize)
-+	{
-+	  wide_int zext = wi::zext (r_const, rl_bitsize);
-+	  if ((rl_unsignedp ? zext : wi::sext (r_const, rl_bitsize)) == r_const)
-+	    r_const = zext;
-+	  else
-+	    r_non_ext_bits = true;
-+	}
-       r_const = wide_int::from (r_const, lnprec, UNSIGNED);
-       if (rl_and_mask.get_precision ())
- 	r_const &= wide_int::from (rl_and_mask, lnprec, UNSIGNED);
-       r_const <<= xrl_bitpos;
--      if ((r_const & ~rl_mask) != 0)
-+      if (r_non_ext_bits || (r_const & ~rl_mask) != 0)
- 	{
- 	  warning_at (rloc, OPT_Wtautological_compare,
- 		      "comparison is always %d", wanted_code == NE_EXPR);
-diff --git a/gcc/testsuite/gcc.dg/field-merge-21.c b/gcc/testsuite/gcc.dg/field-merge-21.c
-new file mode 100644
-index 000000000000..042b2123eb63
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/field-merge-21.c
-@@ -0,0 +1,53 @@
-+/* { dg-do run } */
-+/* { dg-options "-O2" } */
-+
-+/* PR tree-optimization/118456 */
-+/* Check that shifted fields compared with a constants compare correctly even
-+   if the constant contains sign-extension bits not present in the bit
-+   range.  */
-+
-+struct S { unsigned long long o; unsigned short a, b; } s;
-+
-+__attribute__((noipa)) int
-+foo (void)
-+{
-+  return ((unsigned char) s.a) >> 3 == 17 && ((signed char) s.b) >> 2 == -27;
-+}
-+
-+__attribute__((noipa)) int
-+bar (void)
-+{
-+  return ((unsigned char) s.a) >> 3 == 17 && ((signed char) s.b) >> 2 == -91;
-+}
-+
-+__attribute__((noipa)) int
-+bars (void)
-+{
-+  return ((unsigned char) s.a) >> 3 == 17 && ((signed char) s.b) >> 2 == 37;
-+}
-+
-+__attribute__((noipa)) int
-+baz (void)
-+{
-+  return ((unsigned char) s.a) >> 3 == 49 && ((signed char) s.b) >> 2 == -27;
-+}
-+
-+__attribute__((noipa)) int
-+bazs (void)
-+{
-+  return ((unsigned char) s.a) >> 3 == (unsigned char) -15 && ((signed char) s.b) >> 2 == -27;
-+}
-+
-+int
-+main ()
-+{
-+  s.a = 17 << 3;
-+  s.b = (unsigned short)(-27u << 2);
-+  if (foo () != 1
-+      || bar () != 0
-+      || bars () != 0
-+      || baz () != 0
-+      || bazs () != 0)
-+    __builtin_abort ();
-+  return 0;
-+}
-diff --git a/gcc/testsuite/gcc.dg/field-merge-22.c b/gcc/testsuite/gcc.dg/field-merge-22.c
-new file mode 100644
-index 000000000000..45b29c0bccaf
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/field-merge-22.c
-@@ -0,0 +1,31 @@
-+/* { dg-do run } */
-+/* { dg-options "-O2" } */
-+
-+/* PR tree-optimization/118456 */
-+/* Check that compares with constants take into account sign/zero extension of
-+   both the bitfield and of the shifting type.  */
-+
-+#define shift (__CHAR_BIT__ - 4)
-+
-+struct S {
-+  signed char a : shift + 2;
-+  signed char b : shift + 2;
-+  short ignore[0];
-+} s;
-+
-+__attribute__((noipa)) int
-+foo (void)
-+{
-+  return ((unsigned char) s.a) >> shift == 15
-+    && ((unsigned char) s.b) >> shift == 0;
-+}
-+
-+int
-+main ()
-+{
-+  s.a = -1;
-+  s.b = 1;
-+  if (foo () != 1)
-+    __builtin_abort ();
-+  return 0;
-+}
-
-base-commit: 31c3c1a83fd885b4687c9f6f7acd68af76d758d3
--- 
-2.48.0
-
diff --git a/15.0.0/gentoo/85_all_PR118456-robustify-decode_field_reference.patch b/15.0.0/gentoo/85_all_PR118456-robustify-decode_field_reference.patch
deleted file mode 100644
index 065c958..0000000
--- a/15.0.0/gentoo/85_all_PR118456-robustify-decode_field_reference.patch
+++ /dev/null
@@ -1,354 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/or1px6gf6r.fsf@lxoliva.fsfla.org/
-
-From e3a5a707fd88522a73d05841970fa2465e991eaa Mon Sep 17 00:00:00 2001
-Message-ID: <e3a5a707fd88522a73d05841970fa2465e991eaa.1736844127.git.sam@gentoo.org>
-In-Reply-To: <4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192.1736844127.git.sam@gentoo.org>
-References: <4e794a3a5de8e8fa0fcaf98e5ea298d4a3c71192.1736844127.git.sam@gentoo.org>
-From: Alexandre Oliva <oliva@adacore.com>
-Date: Tue, 14 Jan 2025 02:03:24 -0300
-Subject: [PATCH 2/2] robustify decode_field_reference
-
-Arrange for decode_field_reference to use local variables throughout,
-to modify the out parms only when we're about to return non-NULL, and
-to drop the unused case of NULL pand_mask, that had a latent failure
-to detect signbit masking.
-
-Regstrapped on x86_64-linux-gnu along with the PR118456 patch.
-Ok to install?
-
-for  gcc/ChangeLog
-
-* gimple-fold.cc (decode_field_reference): Rebustify to set
-	out parms only when returning non-NULL.
-	(fold_truth_andor_for_ifcombine): Bail if
-	decode_field_reference returns NULL.  Add complementary assert
-	on r_const's not being set when l_const isn't.
----
- gcc/gimple-fold.cc | 155 +++++++++++++++++++++++----------------------
- 1 file changed, 80 insertions(+), 75 deletions(-)
-
-diff --git a/gcc/gimple-fold.cc b/gcc/gimple-fold.cc
-index 5b1fbe6db1df..3c971a29ef04 100644
---- a/gcc/gimple-fold.cc
-+++ b/gcc/gimple-fold.cc
-@@ -7510,18 +7510,17 @@ gimple_binop_def_p (enum tree_code code, tree t, tree op[2])
-    *PREVERSEP is set to the storage order of the field.
- 
-    *PAND_MASK is set to the mask found in a BIT_AND_EXPR, if any.  If
--   PAND_MASK *is NULL, BIT_AND_EXPR is not recognized.  If *PAND_MASK
--   is initially set to a mask with nonzero precision, that mask is
-+   *PAND_MASK is initially set to a mask with nonzero precision, that mask is
-    combined with the found mask, or adjusted in precision to match.
- 
-    *PSIGNBIT is set to TRUE if, before clipping to *PBITSIZE, the mask
-    encompassed bits that corresponded to extensions of the sign bit.
- 
--   *XOR_P is to be FALSE if EXP might be a XOR used in a compare, in which
--   case, if XOR_CMP_OP is a zero constant, it will be overridden with *PEXP,
--   *XOR_P will be set to TRUE, *XOR_PAND_MASK will be copied from *PAND_MASK,
--   and the left-hand operand of the XOR will be decoded.  If *XOR_P is TRUE,
--   XOR_CMP_OP and XOR_PAND_MASK are supposed to be NULL, and then the
-+   *PXORP is to be FALSE if EXP might be a XOR used in a compare, in which
-+   case, if PXOR_CMP_OP is a zero constant, it will be overridden with *PEXP,
-+   *PXORP will be set to TRUE, *PXOR_AND_MASK will be copied from *PAND_MASK,
-+   and the left-hand operand of the XOR will be decoded.  If *PXORP is TRUE,
-+   PXOR_CMP_OP and PXOR_AND_MASK are supposed to be NULL, and then the
-    right-hand operand of the XOR will be decoded.
- 
-    *LOAD is set to the load stmt of the innermost reference, if any,
-@@ -7538,8 +7537,8 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
- 			HOST_WIDE_INT *pbitpos,
- 			bool *punsignedp, bool *preversep, bool *pvolatilep,
- 			wide_int *pand_mask, bool *psignbit,
--			bool *xor_p, tree *xor_cmp_op, wide_int *xor_pand_mask,
--			gimple **load, location_t loc[4])
-+			bool *pxorp, tree *pxor_cmp_op, wide_int *pxor_and_mask,
-+			gimple **pload, location_t loc[4])
- {
-   tree exp = *pexp;
-   tree outer_type = 0;
-@@ -7549,9 +7548,11 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
-   tree res_ops[2];
-   machine_mode mode;
-   bool convert_before_shift = false;
--
--  *load = NULL;
--  *psignbit = false;
-+  bool signbit = false;
-+  bool xorp = false;
-+  tree xor_cmp_op;
-+  wide_int xor_and_mask;
-+  gimple *load = NULL;
- 
-   /* All the optimizations using this function assume integer fields.
-      There are problems with FP fields since the type_for_size call
-@@ -7576,7 +7577,7 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
- 
-   /* Recognize and save a masking operation.  Combine it with an
-      incoming mask.  */
--  if (pand_mask && gimple_binop_def_p (BIT_AND_EXPR, exp, res_ops)
-+  if (gimple_binop_def_p (BIT_AND_EXPR, exp, res_ops)
-       && TREE_CODE (res_ops[1]) == INTEGER_CST)
-     {
-       loc[1] = gimple_location (SSA_NAME_DEF_STMT (exp));
-@@ -7596,29 +7597,29 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
- 	    and_mask &= wide_int::from (*pand_mask, prec_op, UNSIGNED);
- 	}
-     }
--  else if (pand_mask)
-+  else
-     and_mask = *pand_mask;
- 
-   /* Turn (a ^ b) [!]= 0 into a [!]= b.  */
--  if (xor_p && gimple_binop_def_p (BIT_XOR_EXPR, exp, res_ops))
-+  if (pxorp && gimple_binop_def_p (BIT_XOR_EXPR, exp, res_ops))
-     {
-       /* No location recorded for this one, it's entirely subsumed by the
- 	 compare.  */
--      if (*xor_p)
-+      if (*pxorp)
- 	{
- 	  exp = res_ops[1];
--	  gcc_checking_assert (!xor_cmp_op && !xor_pand_mask);
-+	  gcc_checking_assert (!pxor_cmp_op && !pxor_and_mask);
- 	}
--      else if (!xor_cmp_op)
-+      else if (!pxor_cmp_op)
- 	/* Not much we can do when xor appears in the right-hand compare
- 	   operand.  */
- 	return NULL_TREE;
--      else if (integer_zerop (*xor_cmp_op))
-+      else if (integer_zerop (*pxor_cmp_op))
- 	{
--	  *xor_p = true;
-+	  xorp = true;
- 	  exp = res_ops[0];
--	  *xor_cmp_op = *pexp;
--	  *xor_pand_mask = *pand_mask;
-+	  xor_cmp_op = *pexp;
-+	  xor_and_mask = *pand_mask;
- 	}
-     }
- 
-@@ -7646,12 +7647,12 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
-   /* Yet another chance to drop conversions.  This one is allowed to
-      match a converting load, subsuming the load identification block
-      below.  */
--  if (!outer_type && gimple_convert_def_p (exp, res_ops, load))
-+  if (!outer_type && gimple_convert_def_p (exp, res_ops, &load))
-     {
-       outer_type = TREE_TYPE (exp);
-       loc[0] = gimple_location (SSA_NAME_DEF_STMT (exp));
--      if (*load)
--	loc[3] = gimple_location (*load);
-+      if (load)
-+	loc[3] = gimple_location (load);
-       exp = res_ops[0];
-       /* This looks backwards, but we're going back the def chain, so if we
- 	 find the conversion here, after finding a shift, that's because the
-@@ -7662,14 +7663,13 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
-     }
- 
-   /* Identify the load, if there is one.  */
--  if (!(*load) && TREE_CODE (exp) == SSA_NAME
--      && !SSA_NAME_IS_DEFAULT_DEF (exp))
-+  if (!load && TREE_CODE (exp) == SSA_NAME && !SSA_NAME_IS_DEFAULT_DEF (exp))
-     {
-       gimple *def = SSA_NAME_DEF_STMT (exp);
-       if (gimple_assign_load_p (def))
- 	{
- 	  loc[3] = gimple_location (def);
--	  *load = def;
-+	  load = def;
- 	  exp = gimple_assign_rhs1 (def);
- 	}
-     }
-@@ -7694,20 +7694,14 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
- 	  && !type_has_mode_precision_p (TREE_TYPE (inner))))
-     return NULL_TREE;
- 
--  *pbitsize = bs;
--  *pbitpos = bp;
--  *punsignedp = unsignedp;
--  *preversep = reversep;
--  *pvolatilep = volatilep;
--
-   /* Adjust shifts...  */
-   if (convert_before_shift
--      && outer_type && *pbitsize > TYPE_PRECISION (outer_type))
-+      && outer_type && bs > TYPE_PRECISION (outer_type))
-     {
--      HOST_WIDE_INT excess = *pbitsize - TYPE_PRECISION (outer_type);
--      if (*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
--	*pbitpos += excess;
--      *pbitsize -= excess;
-+      HOST_WIDE_INT excess = bs - TYPE_PRECISION (outer_type);
-+      if (reversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
-+	bp += excess;
-+      bs -= excess;
-     }
- 
-   if (shiftrt)
-@@ -7720,49 +7714,57 @@ decode_field_reference (tree *pexp, HOST_WIDE_INT *pbitsize,
- 	 shift after a change of signedness would make the extension
- 	 non-uniform, and we can't deal with that (yet ???).  See
- 	 gcc.dg/field-merge-22.c for a test that would go wrong.  */
--      if (*pbitsize <= shiftrt
-+      if (bs <= shiftrt
- 	  || (convert_before_shift
- 	      && outer_type && unsignedp != TYPE_UNSIGNED (outer_type)))
- 	return NULL_TREE;
--      if (!*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
--	*pbitpos += shiftrt;
--      *pbitsize -= shiftrt;
-+      if (!reversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
-+	bp += shiftrt;
-+      bs -= shiftrt;
-     }
- 
-   /* ... and bit position.  */
-   if (!convert_before_shift
--      && outer_type && *pbitsize > TYPE_PRECISION (outer_type))
-+      && outer_type && bs > TYPE_PRECISION (outer_type))
-     {
--      HOST_WIDE_INT excess = *pbitsize - TYPE_PRECISION (outer_type);
--      if (*preversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
--	*pbitpos += excess;
--      *pbitsize -= excess;
-+      HOST_WIDE_INT excess = bs - TYPE_PRECISION (outer_type);
-+      if (reversep ? !BYTES_BIG_ENDIAN : BYTES_BIG_ENDIAN)
-+	bp += excess;
-+      bs -= excess;
-     }
- 
--  *pexp = exp;
--
-   /* If the number of bits in the reference is the same as the bitsize of
-      the outer type, then the outer type gives the signedness. Otherwise
-      (in case of a small bitfield) the signedness is unchanged.  */
--  if (outer_type && *pbitsize == TYPE_PRECISION (outer_type))
--    *punsignedp = TYPE_UNSIGNED (outer_type);
-+  if (outer_type && bs == TYPE_PRECISION (outer_type))
-+    unsignedp = TYPE_UNSIGNED (outer_type);
- 
--  if (pand_mask)
-+  /* Make the mask the expected width.  */
-+  if (and_mask.get_precision () != 0)
-     {
--      /* Make the mask the expected width.  */
--      if (and_mask.get_precision () != 0)
--	{
--	  /* If the AND_MASK encompasses bits that would be extensions of
--	     the sign bit, set *PSIGNBIT.  */
--	  if (!unsignedp
--	      && and_mask.get_precision () > *pbitsize
--	      && (and_mask
--		  & wi::mask (*pbitsize, true, and_mask.get_precision ())) != 0)
--	    *psignbit = true;
--	  and_mask = wide_int::from (and_mask, *pbitsize, UNSIGNED);
--	}
-+      /* If the AND_MASK encompasses bits that would be extensions of
-+	 the sign bit, set SIGNBIT.  */
-+      if (!unsignedp
-+	  && and_mask.get_precision () > bs
-+	  && (and_mask & wi::mask (bs, true, and_mask.get_precision ())) != 0)
-+	signbit = true;
-+      and_mask = wide_int::from (and_mask, bs, UNSIGNED);
-+    }
- 
--      *pand_mask = and_mask;
-+  *pexp = exp;
-+  *pload = load;
-+  *pbitsize = bs;
-+  *pbitpos = bp;
-+  *punsignedp = unsignedp;
-+  *preversep = reversep;
-+  *pvolatilep = volatilep;
-+  *psignbit = signbit;
-+  *pand_mask = and_mask;
-+  if (xorp)
-+    {
-+      *pxorp = xorp;
-+      *pxor_cmp_op = xor_cmp_op;
-+      *pxor_and_mask = xor_and_mask;
-     }
- 
-   return inner;
-@@ -8168,19 +8170,27 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
- 				     &ll_and_mask, &ll_signbit,
- 				     &l_xor, &lr_arg, &lr_and_mask,
- 				     &ll_load, ll_loc);
-+  if (!ll_inner)
-+    return 0;
-   lr_inner = decode_field_reference (&lr_arg, &lr_bitsize, &lr_bitpos,
- 				     &lr_unsignedp, &lr_reversep, &volatilep,
- 				     &lr_and_mask, &lr_signbit, &l_xor, 0, 0,
- 				     &lr_load, lr_loc);
-+  if (!lr_inner)
-+    return 0;
-   rl_inner = decode_field_reference (&rl_arg, &rl_bitsize, &rl_bitpos,
- 				     &rl_unsignedp, &rl_reversep, &volatilep,
- 				     &rl_and_mask, &rl_signbit,
- 				     &r_xor, &rr_arg, &rr_and_mask,
- 				     &rl_load, rl_loc);
-+  if (!rl_inner)
-+    return 0;
-   rr_inner = decode_field_reference (&rr_arg, &rr_bitsize, &rr_bitpos,
- 				     &rr_unsignedp, &rr_reversep, &volatilep,
- 				     &rr_and_mask, &rr_signbit, &r_xor, 0, 0,
- 				     &rr_load, rr_loc);
-+  if (!rr_inner)
-+    return 0;
- 
-   /* It must be true that the inner operation on the lhs of each
-      comparison must be the same if we are to be able to do anything.
-@@ -8188,16 +8198,13 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
-      the rhs's.  If one is a load and the other isn't, we have to be
-      conservative and avoid the optimization, otherwise we could get
-      SRAed fields wrong.  */
--  if (volatilep
--      || ll_reversep != rl_reversep
--      || ll_inner == 0 || rl_inner == 0)
-+  if (volatilep || ll_reversep != rl_reversep)
-     return 0;
- 
-   if (! operand_equal_p (ll_inner, rl_inner, 0))
-     {
-       /* Try swapping the operands.  */
-       if (ll_reversep != rr_reversep
--	  || !rr_inner
- 	  || !operand_equal_p (ll_inner, rr_inner, 0))
- 	return 0;
- 
-@@ -8266,7 +8273,6 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
-       lr_reversep = ll_reversep;
-     }
-   else if (lr_reversep != rr_reversep
--	   || lr_inner == 0 || rr_inner == 0
- 	   || ! operand_equal_p (lr_inner, rr_inner, 0)
- 	   || ((lr_load && rr_load)
- 	       ? gimple_vuse (lr_load) != gimple_vuse (rr_load)
-@@ -8520,6 +8526,9 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
-   else
-     rl_mask = wi::shifted_mask (xrl_bitpos, rl_bitsize, false, lnprec);
- 
-+  /* When we set l_const, we also set r_const.  */
-+  gcc_checking_assert (!l_const.get_precision () == !r_const.get_precision ());
-+
-   /* Adjust right-hand constants in both original comparisons to match width
-      and bit position.  */
-   if (l_const.get_precision ())
-@@ -8550,10 +8559,6 @@ fold_truth_andor_for_ifcombine (enum tree_code code, tree truth_type,
- 	  return constant_boolean_node (wanted_code == NE_EXPR, truth_type);
- 	}
- 
--      /* When we set l_const, we also set r_const, so we need not test it
--	 again.  */
--      gcc_checking_assert (r_const.get_precision ());
--
-       /* Before clipping upper bits of the right-hand operand of the compare,
- 	 check that they're sign or zero extensions, depending on how the
- 	 left-hand operand would be extended.  */
--- 
-2.48.0
-
diff --git a/15.0.0/gentoo/86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch b/15.0.0/gentoo/86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
deleted file mode 100644
index ce0b338..0000000
--- a/15.0.0/gentoo/86_all_PR118418-Fix-build-for-STORE_FLAG_VALUE-0-targets.patch
+++ /dev/null
@@ -1,87 +0,0 @@
-From a1a14ce3c39c25fecf052ffde063fc0ecfc2ffa3 Mon Sep 17 00:00:00 2001
-Message-ID: <a1a14ce3c39c25fecf052ffde063fc0ecfc2ffa3.1736867096.git.sam@gentoo.org>
-From: Richard Sandiford <richard.sandiford@arm.com>
-Date: Mon, 13 Jan 2025 19:37:12 +0000
-Subject: [PATCH] Fix build for STORE_FLAG_VALUE<0 targets [PR118418]
-
-In g:06c4cf398947b53b4bfc65752f9f879bb2d07924 I mishandled signed
-comparisons of comparison results on STORE_FLAG_VALUE < 0 targets
-(despite specifically referencing STORE_FLAG_VALUE in the commit
-message).  There, (lt TRUE FALSE) is true, although (ltu FALSE TRUE)
-still holds.
-
-Things get messy with vector modes, and since those weren't the focus
-of the original commit, it seemed better to punt on them for now.
-However, punting means that this optimisation no longer feels like
-a natural tail-call operation.  The patch therefore converts
-"return simplify..." to the usual call-and-conditional-return pattern.
-
-gcc/
-	PR target/118418
-	* simplify-rtx.cc (simplify_context::simplify_relational_operation_1):
-	Take STORE_FLAG_VALUE into account when handling signed comparisons
-	of comparison results.
----
- gcc/simplify-rtx.cc | 39 ++++++++++++++++++++++++---------------
- 1 file changed, 24 insertions(+), 15 deletions(-)
-
-diff --git a/gcc/simplify-rtx.cc b/gcc/simplify-rtx.cc
-index 71c5d3c1b1b8..dda8fc689e79 100644
---- a/gcc/simplify-rtx.cc
-+++ b/gcc/simplify-rtx.cc
-@@ -6434,7 +6434,7 @@ simplify_context::simplify_relational_operation_1 (rtx_code code,
- 	return simplify_gen_binary (AND, mode, XEXP (tmp, 0), const1_rtx);
-     }
- 
--  /* For two booleans A and B:
-+  /* For two unsigned booleans A and B:
- 
-      A >  B == ~B & A
-      A >= B == ~B | A
-@@ -6443,20 +6443,29 @@ simplify_context::simplify_relational_operation_1 (rtx_code code,
-      A == B == ~A ^ B (== ~B ^ A)
-      A != B ==  A ^ B
- 
--     simplify_logical_relational_operation checks whether A and B
--     are booleans.  */
--  if (code == GTU || code == GT)
--    return simplify_logical_relational_operation (AND, mode, op1, op0, true);
--  if (code == GEU || code == GE)
--    return simplify_logical_relational_operation (IOR, mode, op1, op0, true);
--  if (code == LTU || code == LT)
--    return simplify_logical_relational_operation (AND, mode, op0, op1, true);
--  if (code == LEU || code == LE)
--    return simplify_logical_relational_operation (IOR, mode, op0, op1, true);
--  if (code == EQ)
--    return simplify_logical_relational_operation (XOR, mode, op0, op1, true);
--  if (code == NE)
--    return simplify_logical_relational_operation (XOR, mode, op0, op1);
-+     For signed comparisons, we have to take STORE_FLAG_VALUE into account,
-+     with the rules above applying for positive STORE_FLAG_VALUE and with
-+     the relations reversed for negative STORE_FLAG_VALUE.  */
-+  if (is_a<scalar_int_mode> (cmp_mode)
-+      && COMPARISON_P (op0)
-+      && COMPARISON_P (op1))
-+    {
-+      rtx t = NULL_RTX;
-+      if (code == GTU || code == (STORE_FLAG_VALUE > 0 ? GT : LT))
-+	t = simplify_logical_relational_operation (AND, mode, op1, op0, true);
-+      else if (code == GEU || code == (STORE_FLAG_VALUE > 0 ? GE : LE))
-+	t = simplify_logical_relational_operation (IOR, mode, op1, op0, true);
-+      else if (code == LTU || code == (STORE_FLAG_VALUE > 0 ? LT : GT))
-+	t = simplify_logical_relational_operation (AND, mode, op0, op1, true);
-+      else if (code == LEU || code == (STORE_FLAG_VALUE > 0 ? LE : GE))
-+	t = simplify_logical_relational_operation (IOR, mode, op0, op1, true);
-+      else if (code == EQ)
-+	t = simplify_logical_relational_operation (XOR, mode, op0, op1, true);
-+      else if (code == NE)
-+	t = simplify_logical_relational_operation (XOR, mode, op0, op1);
-+      if (t)
-+	return t;
-+    }
- 
-   return NULL_RTX;
- }
--- 
-2.48.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 4650c20..1baa80e 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,9 @@
+42	????
+
+	- 82_all_PR118409-ifcombine.patch
+	- 84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
+	- 85_all_PR118456-robustify-decode_field_reference.patch
+
 41	16 January 2025
 
 	+ 82_all_PR118409-ifcombine.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-19 22:43 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-19 22:43 UTC (permalink / raw
  To: gentoo-commits
commit:     5520b28b43a63a664896054573a93352d8fe4ead
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jan 19 22:43:41 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jan 19 22:43:41 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=5520b28b
15.0.0: cut patchset 42
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 1baa80e..3422b22 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-42	????
+42	19 January 2025
 
 	- 82_all_PR118409-ifcombine.patch
 	- 84_all_PR118456-check-and-extend-constants-to-compare-with-bitfields.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-22 16:27 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-22 16:27 UTC (permalink / raw
  To: gentoo-commits
commit:     ed499599c366116171aab1648e7fdb14b70723c8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 22 16:26:40 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jan 22 16:26:55 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ed499599
15.0.0: drop obsolete 81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
An alternative fix was merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...GET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch | 94 ----------------------
 15.0.0/gentoo/README.history                       |  4 +
 2 files changed, 4 insertions(+), 94 deletions(-)
diff --git a/15.0.0/gentoo/81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch b/15.0.0/gentoo/81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
deleted file mode 100644
index b22e9e6..0000000
--- a/15.0.0/gentoo/81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
+++ /dev/null
@@ -1,94 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/01020194380ee046-69c328dc-fad4-4f3f-bb9a-a405679b67fb-000000@eu-west-1.amazonses.com/
-
-From 403c57a863a48014db8124cfe84cfbfd8001c084 Mon Sep 17 00:00:00 2001
-Message-ID: <403c57a863a48014db8124cfe84cfbfd8001c084.1736136592.git.sam@gentoo.org>
-From: Simon Martin <simon@nasilyan.com>
-Date: Sun, 5 Jan 2025 20:01:26 +0000
-Subject: [PATCH] c++: Clear TARGET_EXPR_ELIDING_P when forced to use a copy
- constructor due to __no_unique_address__ [PR118199]
-
-We currently fail with a checking assert upon the following valid code
-when using -fno-elide-constructors
-
-=== cut here ===
-struct d { ~d(); };
-d &b();
-struct f {
-  [[__no_unique_address__]] d e;
-};
-struct h : f  {
-  h() : f{b()} {}
-} i;
-=== cut here ===
-
-The problem is that split_nonconstant_init_1 detects that it cannot
-elide the copy constructor due to __no_unique_address__ but does not
-clear TARGET_EXPR_ELIDING_P, and due to -fno-elide-constructors, we trip
-on a checking assert in cp_gimplify_expr.
-
-This patch fixes this by making sure that we clear TARGET_EXPR_ELIDING_P
-if we determine that we have to keep the copy constructor due to
-__no_unique_address__. An alternative would be to just check for
-elide_constructors in that assert, but I think it'd lose most of its
-value if we did so.
-
-Successfully tested on x86_64-pc-linux-gnu.
-
-	PR c++/118199
-
-gcc/cp/ChangeLog:
-
-	* typeck2.cc (split_nonconstant_init_1): Clear
-	TARGET_EXPR_ELIDING_P if we need to use a copy constructor
-	because of __no_unique_address__.
-
-gcc/testsuite/ChangeLog:
-
-* g++.dg/init/no-elide3.C: New test.
----
- gcc/cp/typeck2.cc                     |  5 +++++
- gcc/testsuite/g++.dg/init/no-elide3.C | 12 ++++++++++++
- 2 files changed, 17 insertions(+)
- create mode 100644 gcc/testsuite/g++.dg/init/no-elide3.C
-
-diff --git a/gcc/cp/typeck2.cc b/gcc/cp/typeck2.cc
-index 381f198d0fe6..f50c5f767bb8 100644
---- a/gcc/cp/typeck2.cc
-+++ b/gcc/cp/typeck2.cc
-@@ -655,6 +655,11 @@ split_nonconstant_init_1 (tree dest, tree init, bool last,
- 			  && make_safe_copy_elision (sub, value))
- 			goto build_init;
- 
-+		      if (TREE_CODE (value) == TARGET_EXPR)
-+			/* We have to add this constructor, so we will not
-+			   elide.  */
-+			TARGET_EXPR_ELIDING_P (value) = false;
-+
- 		      tree name = (DECL_FIELD_IS_BASE (field_index)
- 				   ? base_ctor_identifier
- 				   : complete_ctor_identifier);
-diff --git a/gcc/testsuite/g++.dg/init/no-elide3.C b/gcc/testsuite/g++.dg/init/no-elide3.C
-new file mode 100644
-index 000000000000..659eb19bc95a
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/init/no-elide3.C
-@@ -0,0 +1,12 @@
-+// PR c++/118199
-+// { dg-do "compile" { target c++11 } }
-+// { dg-options "-fno-elide-constructors" } 
-+
-+struct d { ~d(); };
-+d &b();
-+struct f {
-+  [[__no_unique_address__]] d e;
-+};
-+struct h : f  {
-+  h() : f{b()} {}
-+} i;
-
-base-commit: 451ff5b58f7c5958f8341160343680262944a63f
-prerequisite-patch-id: cca034489e37f362f6ff4ff1aba0258270153a6a
-prerequisite-patch-id: dcb0315887787c40fae21980c53d20d0b6e234b7
--- 
-2.47.1
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 3422b22..2865eb6 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+43	????
+
+	- 81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
+
 42	19 January 2025
 
 	- 82_all_PR118409-ifcombine.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-26 22:52 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-26 22:52 UTC (permalink / raw
  To: gentoo-commits
commit:     43f8fd917f4f080aee81e0677df429aa4eb23100
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jan 26 22:51:45 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jan 26 22:51:45 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=43f8fd91
15.0.0: cut patchset 43
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 2865eb6..0b37fe9 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-43	????
+43	26 Janaury 2025
 
 	- 81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-01-29 20:21 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-01-29 20:21 UTC (permalink / raw
  To: gentoo-commits
commit:     1bc5d3df1805f0f48a9262c053f88fc1d80ca0a6
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 29 20:21:06 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jan 29 20:21:06 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=1bc5d3df
15.0.0: drop D parallel make patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-d-give-dependency-files-better-filenames.patch | 54 ----------------------
 1 file changed, 54 deletions(-)
diff --git a/15.0.0/gentoo/83_all-gcc-d-give-dependency-files-better-filenames.patch b/15.0.0/gentoo/83_all-gcc-d-give-dependency-files-better-filenames.patch
deleted file mode 100644
index 98156e4..0000000
--- a/15.0.0/gentoo/83_all-gcc-d-give-dependency-files-better-filenames.patch
+++ /dev/null
@@ -1,54 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/20250112153348.1578402-1-arsen@aarsen.me/
-
-From 327b1b3834b4e3c80b209a35a73b063a0f9bfd75 Mon Sep 17 00:00:00 2001
-Message-ID: <327b1b3834b4e3c80b209a35a73b063a0f9bfd75.1736738577.git.sam@gentoo.org>
-From: =?UTF-8?q?Arsen=20Arsenovi=C4=87?= <arsen@aarsen.me>
-Date: Sun, 12 Jan 2025 16:16:58 +0100
-Subject: [PATCH] gcc/d: give dependency files better filenames
-
-Currently, the dependency files for root-file.o and common-file.o were
-both d/.deps/file.Po, which would cause parallel builds to fail
-sometimes with:
-
-  make[3]: Leaving directory '/var/tmp/portage/sys-devel/gcc-14.1.1_p20240511/work/build/gcc'
-  make[3]: Entering directory '/var/tmp/portage/sys-devel/gcc-14.1.1_p20240511/work/build/gcc'
-  mv: cannot stat 'd/.deps/file.TPo': No such file or directory
-  make[3]: *** [/var/tmp/portage/sys-devel/gcc-14.1.1_p20240511/work/gcc-14-20240511/gcc/d/Make-lang.in:421: d/root-file.o] Error 1 shuffle=131581365
-
-Also, this means that dependencies of one of root-file or common-file
-are missing when developing.  After this patch, those two files get
-assigned dependency files d/.deps/d-root-file.o.Po and
-d/.deps/d-common-file.o.Po respectively.
-
-There are other files with similar conflicts (mangle-package.o,
-visitor-package.o for instance).
-
-gcc/d/ChangeLog:
-
-* Make-lang.in: Assign dependency-tracking files better
-	filenames.
----
- gcc/d/Make-lang.in | 5 +++--
- 1 file changed, 3 insertions(+), 2 deletions(-)
-
-diff --git a/gcc/d/Make-lang.in b/gcc/d/Make-lang.in
-index f28761e4b370..25e2b0bbfe94 100644
---- a/gcc/d/Make-lang.in
-+++ b/gcc/d/Make-lang.in
-@@ -65,8 +65,9 @@ ALL_DFLAGS = $(DFLAGS-$@) $(GDCFLAGS) -fversion=IN_GCC $(CHECKING_DFLAGS) \
- 	$(WARN_DFLAGS)
- 
- DCOMPILE.base = $(GDC) -c $(ALL_DFLAGS) -o $@
--DCOMPILE = $(DCOMPILE.base) -MT $@ -MMD -MP -MF $(@D)/$(DEPDIR)/$(*F).TPo
--DPOSTCOMPILE = @mv $(@D)/$(DEPDIR)/$(*F).TPo $(@D)/$(DEPDIR)/$(*F).Po
-+DEPFILE = $(subst /,-,$@)
-+DCOMPILE = $(DCOMPILE.base) -MT $@ -MMD -MP -MF $(@D)/$(DEPDIR)/$(DEPFILE).TPo
-+DPOSTCOMPILE = @mv $(@D)/$(DEPDIR)/$(DEPFILE).TPo $(@D)/$(DEPDIR)/$(DEPFILE).Po
- DLINKER = $(GDC) $(NO_PIE_FLAG) -lstdc++
- 
- # Like LINKER, but use a mutex for serializing front end links.
-
-base-commit: 0e05b793fba2a9bea9f0fbb1f068679f5dadf514
--- 
-2.48.0
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-02-02 22:41 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-02-02 22:41 UTC (permalink / raw
  To: gentoo-commits
commit:     914f6bcae65e13ee8e16134fe2b2357be9c02042
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Feb  2 22:40:40 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Feb  2 22:40:57 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=914f6bca
15.0.0: cut patchset 44
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 0b37fe9..975777d 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+44	2 February 2025
+
+	- 83_all-gcc-d-give-dependency-files-better-filenames.patch
+
 43	26 Janaury 2025
 
 	- 81_all_PR118199-c-Clear-TARGET_EXPR_ELIDING_P-when-forced-to-use-a-c.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-02-03 22:04 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-02-03 22:04 UTC (permalink / raw
  To: gentoo-commits
commit:     601d2479a8464e3bf1fb53065109a027db7c93f1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Feb  3 22:03:53 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Feb  3 22:03:53 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=601d2479
15.0.0: drop coro patches
Some of these are landed/landing.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/70_all_PR116506-coro.patch | 295 -------------------------------
 15.0.0/gentoo/71_all_PR116914-coro.patch |  51 ------
 2 files changed, 346 deletions(-)
diff --git a/15.0.0/gentoo/70_all_PR116506-coro.patch b/15.0.0/gentoo/70_all_PR116506-coro.patch
deleted file mode 100644
index 4e670fc..0000000
--- a/15.0.0/gentoo/70_all_PR116506-coro.patch
+++ /dev/null
@@ -1,295 +0,0 @@
-From 06475fcc5b72fdb9b24e7e39703942e1e3f2f0d5 Mon Sep 17 00:00:00 2001
-From: Iain Sandoe <iain@sandoe.co.uk>
-Date: Thu, 29 Aug 2024 11:18:24 +0100
-Subject: [PATCH] c++, coroutines: Fix awaiter var creation [PR116506].
-
-Awaiters always need to have a coroutine state frame copy since
-they persist across potential supensions.  It simplifies the later
-analysis considerably to assign these early which we do when
-building co_await expressions.
-
-The cleanups in r15-3146-g47dbd69b1, unfortunately elided some of
-processing used to cater for cases where the var created from an
-xvalue, or is a pointer/reference type.
-
-Corrected thus.
-
-	PR c++/116506
-	PR c++/116880
-
-gcc/cp/ChangeLog:
-
-	* coroutines.cc (build_co_await): Ensure that xvalues are
-	materialised.  Handle references/pointer values in awaiter
-	access expressions.
-
-gcc/testsuite/ChangeLog:
-
-	* g++.dg/coroutines/pr116506.C: New test.
-	* g++.dg/coroutines/pr116880.C: New test.
-
-Signed-off-by: Iain Sandoe <iain@sandoe.co.uk>
----
- gcc/cp/coroutines.cc                       | 82 +++++++++++++++++-----
- gcc/testsuite/g++.dg/coroutines/pr116506.C | 53 ++++++++++++++
- gcc/testsuite/g++.dg/coroutines/pr116880.C | 36 ++++++++++
- 3 files changed, 154 insertions(+), 17 deletions(-)
- create mode 100644 gcc/testsuite/g++.dg/coroutines/pr116506.C
- create mode 100644 gcc/testsuite/g++.dg/coroutines/pr116880.C
-
-diff --git a/gcc/cp/coroutines.cc b/gcc/cp/coroutines.cc
-index 86a5ac8999a..ba6ee41a4e7 100644
---- a/gcc/cp/coroutines.cc
-+++ b/gcc/cp/coroutines.cc
-@@ -1071,6 +1071,30 @@ build_template_co_await_expr (location_t kw, tree type, tree expr, tree kind)
-   return aw_expr;
- }
- 
-+/* For a component ref that is not a pointer type, decide if we can use
-+   this directly.  */
-+static bool
-+usable_component_ref (tree comp_ref)
-+{
-+  if (TREE_CODE (comp_ref) != COMPONENT_REF
-+      || TREE_SIDE_EFFECTS (comp_ref))
-+    return false;
-+
-+  while (TREE_CODE (comp_ref) == COMPONENT_REF)
-+    {
-+      comp_ref = TREE_OPERAND (comp_ref, 0);
-+      STRIP_NOPS (comp_ref);
-+      /* x-> */
-+      if (INDIRECT_REF_P (comp_ref))
-+	return false;
-+      /* operator-> */
-+      if (TREE_CODE (comp_ref) == CALL_EXPR)
-+	return false;
-+      STRIP_NOPS (comp_ref);
-+    }
-+  gcc_checking_assert (VAR_P (comp_ref) || TREE_CODE (comp_ref) == PARM_DECL);
-+  return true;
-+}
- 
- /*  This performs [expr.await] bullet 3.3 and validates the interface obtained.
-     It is also used to build the initial and final suspend points.
-@@ -1133,13 +1157,12 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
-   if (o_type && !VOID_TYPE_P (o_type))
-     o_type = complete_type_or_else (o_type, o);
- 
--  if (!o_type)
-+  if (!o_type || o_type == error_mark_node)
-     return error_mark_node;
- 
-   if (TREE_CODE (o_type) != RECORD_TYPE)
-     {
--      error_at (loc, "awaitable type %qT is not a structure",
--		o_type);
-+      error_at (loc, "awaitable type %qT is not a structure", o_type);
-       return error_mark_node;
-     }
- 
-@@ -1165,20 +1188,47 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
-   if (!glvalue_p (o))
-     o = get_target_expr (o, tf_warning_or_error);
- 
--  tree e_proxy = o;
--  if (glvalue_p (o))
-+  /* We know that we need a coroutine state frame variable for the awaiter,
-+     since it must persist across suspension; so where one is needed, build
-+     it now.  */
-+  tree e_proxy = STRIP_NOPS (o);
-+  if (INDIRECT_REF_P (e_proxy))
-+    e_proxy = TREE_OPERAND (e_proxy, 0);
-+  o_type = TREE_TYPE (e_proxy);
-+  bool is_ptr = TYPE_PTR_P (o_type);
-+  if (!is_ptr
-+      && (TREE_CODE (e_proxy) == PARM_DECL
-+	  || usable_component_ref (e_proxy)
-+	  || (VAR_P (e_proxy) && !is_local_temp (e_proxy))))
-     o = NULL_TREE; /* Use the existing entity.  */
--  else /* We need to materialise it.  */
-+  else /* We need a non-temp var.  */
-     {
--      e_proxy = get_awaitable_var (suspend_kind, o_type);
--      o = cp_build_init_expr (loc, e_proxy, o);
--      e_proxy = convert_from_reference (e_proxy);
-+      tree p_type = o_type;
-+      tree o_a = o;
-+      if (lvalue_p (o) && !TREE_SIDE_EFFECTS (o))
-+	{
-+	  if (is_ptr)
-+	    p_type = TREE_TYPE (p_type);
-+	  p_type = cp_build_reference_type (p_type, false);
-+	  o_a = build_address (o);
-+	}
-+      if (INDIRECT_REF_P (o_a))
-+	o_a = TREE_OPERAND (o_a, 0);
-+      e_proxy = get_awaitable_var (suspend_kind, p_type);
-+      o = cp_build_init_expr (loc, e_proxy, o_a);
-     }
- 
-+  /* Build an expression for the object that will be used to call the awaitable
-+     methods.  */
-+  tree e_object = convert_from_reference (e_proxy);
-+  if (TYPE_PTR_P (TREE_TYPE (e_object)))
-+    e_object = cp_build_indirect_ref (input_location, e_object, RO_UNARY_STAR,
-+				      tf_warning_or_error);
-+
-   /* I suppose we could check that this is contextually convertible to bool.  */
-   tree awrd_func = NULL_TREE;
-   tree awrd_call
--    = build_new_method_call (e_proxy, awrd_meth, NULL, NULL_TREE, LOOKUP_NORMAL,
-+    = build_new_method_call (e_object, awrd_meth, NULL, NULL_TREE, LOOKUP_NORMAL,
- 			     &awrd_func, tf_warning_or_error);
- 
-   if (!awrd_func || !awrd_call || awrd_call == error_mark_node)
-@@ -1192,7 +1242,7 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
-   tree h_proxy = get_coroutine_self_handle_proxy (current_function_decl);
-   vec<tree, va_gc> *args = make_tree_vector_single (h_proxy);
-   tree awsp_call
--    = build_new_method_call (e_proxy, awsp_meth, &args, NULL_TREE,
-+    = build_new_method_call (e_object, awsp_meth, &args, NULL_TREE,
- 			     LOOKUP_NORMAL, &awsp_func, tf_warning_or_error);
- 
-   release_tree_vector (args);
-@@ -1224,7 +1274,7 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
-   /* Finally, the type of e.await_resume() is the co_await's type.  */
-   tree awrs_func = NULL_TREE;
-   tree awrs_call
--    = build_new_method_call (e_proxy, awrs_meth, NULL, NULL_TREE, LOOKUP_NORMAL,
-+    = build_new_method_call (e_object, awrs_meth, NULL, NULL_TREE, LOOKUP_NORMAL,
- 			     &awrs_func, tf_warning_or_error);
- 
-   if (!awrs_func || !awrs_call || awrs_call == error_mark_node)
-@@ -1238,7 +1288,7 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
- 	return error_mark_node;
-       if (coro_diagnose_throwing_fn (awrs_func))
- 	return error_mark_node;
--      if (tree dummy = cxx_maybe_build_cleanup (e_proxy, tf_none))
-+      if (tree dummy = cxx_maybe_build_cleanup (e_object, tf_none))
- 	{
- 	  if (CONVERT_EXPR_P (dummy))
- 	    dummy = TREE_OPERAND (dummy, 0);
-@@ -1249,7 +1299,8 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
-     }
- 
-   /* We now have three call expressions, in terms of the promise, handle and
--     'e' proxies.  Save them in the await expression for later expansion.  */
-+     'e' proxy expression.  Save them in the await expression for later
-+     expansion.  */
- 
-   tree awaiter_calls = make_tree_vec (3);
-   TREE_VEC_ELT (awaiter_calls, 0) = awrd_call; /* await_ready().  */
-@@ -1262,9 +1313,6 @@ build_co_await (location_t loc, tree a, suspend_point_kind suspend_kind,
-     }
-   TREE_VEC_ELT (awaiter_calls, 2) = awrs_call; /* await_resume().  */
- 
--  if (REFERENCE_REF_P (e_proxy))
--    e_proxy = TREE_OPERAND (e_proxy, 0);
--
-   tree awrs_type = TREE_TYPE (TREE_TYPE (awrs_func));
-   tree suspend_kind_cst = build_int_cst (integer_type_node,
- 					 (int) suspend_kind);
-diff --git a/gcc/testsuite/g++.dg/coroutines/pr116506.C b/gcc/testsuite/g++.dg/coroutines/pr116506.C
-new file mode 100644
-index 00000000000..57a6e360566
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/coroutines/pr116506.C
-@@ -0,0 +1,53 @@
-+// { dg-do run }
-+// { dg-additional-options "-fno-exceptions" }
-+                                                       
-+#include <coroutine>
-+
-+bool g_too_early = true;
-+std::coroutine_handle<> g_handle;
-+
-+struct Awaiter {
-+    Awaiter() {}
-+    ~Awaiter() {
-+        if (g_too_early) {
-+            __builtin_abort ();
-+        }
-+    }
-+
-+    bool await_ready() { return false; }
-+    void await_suspend(std::coroutine_handle<> handle) {
-+        g_handle = handle;
-+    }
-+
-+    void await_resume() {}
-+};
-+
-+struct SuspendNever {
-+    bool await_ready() noexcept { return true; }
-+    void await_suspend(std::coroutine_handle<>) noexcept {}
-+    void await_resume() noexcept {}
-+};
-+
-+struct Coroutine {
-+    struct promise_type {
-+        Coroutine get_return_object() { return {}; }
-+        SuspendNever initial_suspend() { return {}; }
-+        SuspendNever final_suspend() noexcept { return {}; }
-+        void return_void() {}
-+        void unhandled_exception() {}
-+
-+        Awaiter&& await_transform(Awaiter&& u) {
-+            return static_cast<Awaiter&&>(u);
-+        }
-+    };
-+};
-+
-+Coroutine foo() {
-+    co_await Awaiter{};
-+}
-+
-+int main() {
-+    foo();
-+    g_too_early = false;
-+    g_handle.destroy();
-+}
-diff --git a/gcc/testsuite/g++.dg/coroutines/pr116880.C b/gcc/testsuite/g++.dg/coroutines/pr116880.C
-new file mode 100644
-index 00000000000..f0db6a26044
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/coroutines/pr116880.C
-@@ -0,0 +1,36 @@
-+#include <coroutine>
-+
-+struct promise_type;
-+using handle_type = std::coroutine_handle<promise_type>;
-+
-+struct Co {
-+    handle_type handle;
-+    using promise_type = ::promise_type;
-+
-+    explicit Co(handle_type handle) : handle(handle) {}
-+
-+    bool await_ready() { return false; }
-+    std::coroutine_handle<> await_suspend(handle_type handle);
-+    void await_resume() {}
-+};
-+
-+struct Done {};
-+
-+struct promise_type {
-+    Co get_return_object();
-+
-+    std::suspend_always initial_suspend() { return {}; };
-+    std::suspend_always final_suspend() noexcept { return {}; };
-+    void return_value(Done) {}
-+    void return_value(Co&&);
-+    void unhandled_exception() { throw; };
-+    Co&& await_transform(Co&& co) { return static_cast<Co&&>(co); }
-+};
-+
-+Co tryToRun();
-+
-+Co init()
-+{
-+    co_await tryToRun();
-+    co_return Done{};
-+}
--- 
-2.39.2 (Apple Git-143)
diff --git a/15.0.0/gentoo/71_all_PR116914-coro.patch b/15.0.0/gentoo/71_all_PR116914-coro.patch
deleted file mode 100644
index 100d2bb..0000000
--- a/15.0.0/gentoo/71_all_PR116914-coro.patch
+++ /dev/null
@@ -1,51 +0,0 @@
-From 1035866a75b27bb2cac49bac1070877d95f7d3c0 Mon Sep 17 00:00:00 2001
-From: Iain Sandoe <iain@sandoe.co.uk>
-Date: Sun, 29 Sep 2024 10:04:39 +0100
-Subject: [PATCH] c++, coroutines: stmt expressions some progress
-
----
- gcc/cp/coroutines.cc | 22 ++++++++++++++++++++++
- 1 file changed, 22 insertions(+)
-
-diff --git a/gcc/cp/coroutines.cc b/gcc/cp/coroutines.cc
-index af8798b04ba..94bfa6ac450 100644
---- a/gcc/cp/coroutines.cc
-+++ b/gcc/cp/coroutines.cc
-@@ -2131,6 +2131,14 @@ await_statement_expander (tree *stmt, int *do_subtree, void *d)
-     }
-   else if (EXPR_P (*stmt))
-     {
-+      /* Look for ({}) at the top level - just recurse into these.  */
-+      if (TREE_CODE (*stmt) == EXPR_STMT)
-+	{
-+	  tree inner = EXPR_STMT_EXPR (*stmt);
-+	  if (TREE_CODE (inner) == STATEMENT_LIST
-+	      || TREE_CODE (inner) == BIND_EXPR)
-+	    return NULL_TREE; // process contents
-+	}
-       process_one_statement (stmt, d);
-       *do_subtree = 0; /* Done subtrees.  */
-     }
-@@ -3860,6 +3868,20 @@ await_statement_walker (tree *stmt, int *do_subtree, void *d)
-       if (!(cp_walk_tree (stmt, find_any_await, &await_ptr, &visited)))
- 	return NULL_TREE; /* Nothing special to do here.  */
- 
-+      /* Handle statement expressions.  */
-+      if (TREE_CODE (expr) == EXPR_STMT)
-+	{
-+	  tree inner = EXPR_STMT_EXPR (expr);
-+	  if (TREE_CODE (inner) == STATEMENT_LIST
-+	      || TREE_CODE (inner) == BIND_EXPR)
-+	    {
-+	      res = cp_walk_tree (&EXPR_STMT_EXPR (expr),
-+				  await_statement_walker, d, NULL);
-+	      *do_subtree = 0;
-+	      return res;
-+	    }
-+	}
-+
-       visited.empty ();
-       awpts->saw_awaits = 0;
-       hash_set<tree> truth_aoif_to_expand;
--- 
-2.39.2 (Apple Git-143)
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-02-07 21:19 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-02-07 21:19 UTC (permalink / raw
  To: gentoo-commits
commit:     c088e880493faa16c2684fced43a2eb4cb67fe23
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Sat Jan  4 21:49:18 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Feb  7 21:18:50 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=c088e880
15.0.0: Update esysroot patch to fix prefix and Canadian Cross issues
Closes: https://bugs.gentoo.org/942672
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
Closes: https://github.com/gentoo/gcc-patches/pull/7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/09_all_esysroot.patch | 77 ++++++++++++++++++++++++-------------
 15.0.0/gentoo/README.history        |  6 ++-
 2 files changed, 56 insertions(+), 27 deletions(-)
diff --git a/15.0.0/gentoo/09_all_esysroot.patch b/15.0.0/gentoo/09_all_esysroot.patch
index 80e0561..85a4b5e 100644
--- a/15.0.0/gentoo/09_all_esysroot.patch
+++ b/15.0.0/gentoo/09_all_esysroot.patch
@@ -1,67 +1,92 @@
-From 71e048084d32811f6e17e73b6ebadfe550ef1193 Mon Sep 17 00:00:00 2001
+From c012b20eca546ec60878058094e59267ebfba1a9 Mon Sep 17 00:00:00 2001
 From: James Le Cuirot <chewi@gentoo.org>
-Date: Sun, 4 Aug 2024 17:02:06 +0100
-Subject: [PATCH] Allow setting target sysroot with ESYSROOT env var for
+Date: Mon, 23 Dec 2024 16:50:25 +0000
+Subject: [PATCH 3/3] Allow setting target sysroot with ESYSROOT env var for
  cross-compilers
 
-The variable is ignored for native compilers. The --sysroot command line
-option takes precedence.
+The variable is ignored for native compilers, when it matches BROOT, and
+when the target machine does not match CHOST (if set). The --sysroot
+command line option takes precedence.
+
+The CHOST check is necessary for a Canadian Cross. In that case, two
+cross-compilers are invoked, but only the one matching CHOST should have
+its sysroot set by ESYSROOT.
 
 Signed-off-by: James Le Cuirot <chewi@gentoo.org>
 ---
- gcc/doc/invoke.texi | 10 ++++++++++
- gcc/gcc.cc          | 10 ++++++++++
- 2 files changed, 20 insertions(+)
+ gcc/doc/invoke.texi | 11 +++++++++++
+ gcc/gcc.cc          | 29 +++++++++++++++++++++++++++++
+ 2 files changed, 40 insertions(+)
 
 diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
-index 0fe99ca8e..434cf30e2 100644
+index 0a7a81b20..d66f53b65 100644
 --- a/gcc/doc/invoke.texi
 +++ b/gcc/doc/invoke.texi
-@@ -19230,6 +19230,10 @@ for this option.  If your linker does not support this option, the
+@@ -19355,6 +19355,10 @@ for this option.  If your linker does not support this option, the
  header file aspect of @option{--sysroot} still works, but the
  library aspect does not.
  
 +On Gentoo Linux, this option can also be set for cross-compilers using the
-+@env{ESYSROOT} environmnent variable.  The variable is ignored for native
-+compilers.  The command line option takes precedence.
++@env{ESYSROOT} environmnent variable.  The command line option takes
++precedence.
 +
  @opindex no-sysroot-suffix
  @item --no-sysroot-suffix
  For some targets, a suffix is added to the root directory specified
-@@ -37657,6 +37661,12 @@ using GCC also uses these directories when searching for ordinary
+@@ -37590,6 +37594,13 @@ using GCC also uses these directories when searching for ordinary
  libraries for the @option{-l} option (but directories specified with
  @option{-L} come first).
  
 +@vindex ESYSROOT
 +@item ESYSROOT
 +On Gentoo Linux, this variable sets the logical root directory for headers and
-+libraries for cross-compilers.  It is ignored for native compilers.  The
-+@option{--sysroot} option takes precedence.
++libraries for cross-compilers.  It is ignored for native compilers, when it
++matches @env{BROOT}, and when the target machine does not match @env{CHOST}
++(if set).  The @option{--sysroot} option takes precedence.
 +
  @vindex LANG
  @cindex locale definition
  @item LANG
 diff --git a/gcc/gcc.cc b/gcc/gcc.cc
-index abdb40bfe..956363ddb 100644
+index 4188f0049..e88c7067f 100644
 --- a/gcc/gcc.cc
 +++ b/gcc/gcc.cc
-@@ -5516,6 +5516,16 @@ process_command (unsigned int decoded_options_count,
- 	      "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
-   free (tooldir_prefix);
+@@ -5486,6 +5486,35 @@ process_command (unsigned int decoded_options_count,
+       gcc_assert (!compare_debug_opt);
+     }
  
 +  if (*cross_compile == '1' && !target_system_root_changed)
 +    {
 +      const char *esysroot = env.get("ESYSROOT");
-+      if (esysroot && esysroot[0] != '\0' && strcmp(esysroot, "/") != 0 && (!target_system_root || strcmp(esysroot, target_system_root) != 0))
++      const char *chost = env.get("CHOST");
++      if (esysroot && (!chost || strcmp(chost, spec_machine) == 0))
 +	{
-+	  target_system_root = esysroot;
-+	  target_system_root_changed = 1;
++	  char *my_esysroot = lrealpath(esysroot);
++	  if (my_esysroot[0] == '\0')
++	    my_esysroot = xstrdup("/");
++
++	  if (!target_system_root ||
++	      !filename_eq(my_esysroot, target_system_root[0] == '\0' ? "/" : target_system_root))
++	    {
++	      const char *broot = env.get("BROOT");
++	      char *my_broot = (!broot || broot[0] == '\0') ? xstrdup("/") : lrealpath(broot);
++
++	      if (!filename_eq(my_esysroot, my_broot))
++		{
++		  target_system_root = esysroot;
++		  target_system_root_changed = 1;
++		}
++
++	      free(my_broot);
++	    }
++
++	  free(my_esysroot);
 +	}
 +    }
 +
- #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
-   /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
-      then consider it to relocate with the rest of the GCC installation
+   /* Set up the search paths.  We add directories that we expect to
+      contain GNU Toolchain components before directories specified by
+      the machine description so that we will find GNU components (like
 -- 
-2.45.2
+2.47.1
 
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 975777d..bac4f3e 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+45	????
+
+	U 09_all_esysroot.patch
+
 44	2 February 2025
 
 	- 83_all-gcc-d-give-dependency-files-better-filenames.patch
@@ -117,7 +121,7 @@
 
 21	1 November 2024
 
-	+ 31_all_time64.patch	
+	+ 31_all_time64.patch
 
 20	28 October 2024
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-02-07 23:37 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-02-07 23:37 UTC (permalink / raw
  To: gentoo-commits
commit:     509a72e881767d24aee2865435c1e7851d46abd3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Feb  7 23:37:06 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Feb  7 23:37:23 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=509a72e8
15.0.0: add ipa-cp patch
Bug: https://gcc.gnu.org/PR118097
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...orm-operations-in-the-appropriate-types-P.patch | 271 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 272 insertions(+)
diff --git a/15.0.0/gentoo/81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch b/15.0.0/gentoo/81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
new file mode 100644
index 0000000..165793d
--- /dev/null
+++ b/15.0.0/gentoo/81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
@@ -0,0 +1,271 @@
+From 70951aa9a0c324893d957da614fcc8c749571a52 Mon Sep 17 00:00:00 2001
+Message-ID: <70951aa9a0c324893d957da614fcc8c749571a52.1738971381.git.sam@gentoo.org>
+From: Martin Jambor <mjambor@suse.cz>
+Date: Wed, 22 Jan 2025 17:44:48 +0100
+Subject: [PATCH] ipa-cp: Perform operations in the appropriate types (PR
+ 118097)
+
+Hi,
+
+one of the testcases from PR 118097 and the one from PR 118535 show
+that the fix to PR 118138 was incomplete.  We must not only make sure
+that (intermediate) results of operations performed by IPA-CP are
+fold_converted to the type of the destination formal parameter but we
+also must decouple the these types from the ones in which operations
+are performed.
+
+This patch does that, even though we do not store or stream the
+operation types, instead we simply limit ourselves to tcc_comparisons
+and operations for which the first operand and the result are of the
+same type as determined by expr_type_first_operand_type_p.  If we
+wanted to go beyond these, we would indeed need to store/stream the
+respective operation type.
+
+ipa_value_from_jfunc needs an additional check that res_type is not
+NULL because it is not called just from within IPA-CP (where we know
+we have a destination lattice slot belonging to a defined parameter)
+but also from inlining, ipa-fnsummary and ipa-modref where it is used
+to examine a call to a function with variadic arguments and we do not
+have types for the unknown parameters.  But we cannot really work with
+those or estimate any benefits when it comes to them, so ignoring them
+should be OK.
+
+Even after this patch, ipa_get_jf_arith_result has a parameter called
+res_type in which it performs operations for aggregate jump functions,
+where we do not allow type conversions when constucting the jump
+functions and the type is the type of the stored data.  In GCC 16, we
+could relax this and allow conversions like for scalars.
+
+Bootstrapped, LTO-bootstrapped and tested on x86_64-linux.  OK for
+master?
+
+Thanks,
+
+Honza
+
+gcc/ChangeLog:
+
+2025-01-20  Martin Jambor  <mjambor@suse.cz>
+
+	PR ipa/118097
+	* ipa-cp.cc (ipa_get_jf_arith_result): Adjust comment.
+	(ipa_get_jf_pass_through_result): Removed.
+	(ipa_value_from_jfunc): Use directly ipa_get_jf_arith_result, do
+	not specify operation type but make sure we check and possibly
+	convert the result.
+	(get_val_across_arith_op): Remove the last parameter, always pass
+	NULL_TREE to ipa_get_jf_arith_result in its last argument.
+	(propagate_vals_across_arith_jfunc): Do not pass res_type to
+	get_val_across_arith_op.
+	(propagate_vals_across_pass_through): Add checking assert that
+	parm_type is not NULL.
+
+gcc/testsuite/ChangeLog:
+
+2025-01-20  Martin Jambor  <mjambor@suse.cz>
+
+PR ipa/118097
+	* gcc.dg/ipa/pr118097.c: New test.
+	* gcc.dg/ipa/pr118535.c: Likewise.
+	* gcc.dg/ipa/ipa-notypes-1.c: Likewise.
+---
+ gcc/ipa-cp.cc                            | 46 ++++++++++--------------
+ gcc/testsuite/gcc.dg/ipa/ipa-notypes-1.c | 17 +++++++++
+ gcc/testsuite/gcc.dg/ipa/pr118097.c      | 23 ++++++++++++
+ gcc/testsuite/gcc.dg/ipa/pr118535.c      | 17 +++++++++
+ 4 files changed, 75 insertions(+), 28 deletions(-)
+ create mode 100644 gcc/testsuite/gcc.dg/ipa/ipa-notypes-1.c
+ create mode 100644 gcc/testsuite/gcc.dg/ipa/pr118097.c
+ create mode 100644 gcc/testsuite/gcc.dg/ipa/pr118535.c
+
+diff --git a/gcc/ipa-cp.cc b/gcc/ipa-cp.cc
+index d89324a00775..68959f2677ba 100644
+--- a/gcc/ipa-cp.cc
++++ b/gcc/ipa-cp.cc
+@@ -1467,11 +1467,10 @@ ipacp_value_safe_for_type (tree param_type, tree value)
+     return NULL_TREE;
+ }
+ 
+-/* Return the result of a (possibly arithmetic) operation on the constant
+-   value INPUT.  OPERAND is 2nd operand for binary operation.  RES_TYPE is
+-   the type of the parameter to which the result is passed.  Return
+-   NULL_TREE if that cannot be determined or be considered an
+-   interprocedural invariant.  */
++/* Return the result of a (possibly arithmetic) operation on the constant value
++   INPUT.  OPERAND is 2nd operand for binary operation.  RES_TYPE is the type
++   in which any operation is to be performed.  Return NULL_TREE if that cannot
++   be determined or be considered an interprocedural invariant.  */
+ 
+ static tree
+ ipa_get_jf_arith_result (enum tree_code opcode, tree input, tree operand,
+@@ -1513,21 +1512,6 @@ ipa_get_jf_arith_result (enum tree_code opcode, tree input, tree operand,
+   return res;
+ }
+ 
+-/* Return the result of a (possibly arithmetic) pass through jump function
+-   JFUNC on the constant value INPUT.  RES_TYPE is the type of the parameter
+-   to which the result is passed.  Return NULL_TREE if that cannot be
+-   determined or be considered an interprocedural invariant.  */
+-
+-static tree
+-ipa_get_jf_pass_through_result (struct ipa_jump_func *jfunc, tree input,
+-				tree res_type)
+-{
+-  return ipa_get_jf_arith_result (ipa_get_jf_pass_through_operation (jfunc),
+-				  input,
+-				  ipa_get_jf_pass_through_operand (jfunc),
+-				  res_type);
+-}
+-
+ /* Return the result of an ancestor jump function JFUNC on the constant value
+    INPUT.  Return NULL_TREE if that cannot be determined.  */
+ 
+@@ -1595,7 +1579,14 @@ ipa_value_from_jfunc (class ipa_node_params *info, struct ipa_jump_func *jfunc,
+ 	return NULL_TREE;
+ 
+       if (jfunc->type == IPA_JF_PASS_THROUGH)
+-	return ipa_get_jf_pass_through_result (jfunc, input, parm_type);
++	{
++	  if (!parm_type)
++	    return NULL_TREE;
++	  enum tree_code opcode = ipa_get_jf_pass_through_operation (jfunc);
++	  tree op2 = ipa_get_jf_pass_through_operand (jfunc);
++	  tree cstval = ipa_get_jf_arith_result (opcode, input, op2, NULL_TREE);
++	  return ipacp_value_safe_for_type (parm_type, cstval);
++	}
+       else
+ 	return ipa_get_jf_ancestor_result (jfunc, input);
+     }
+@@ -2120,15 +2111,13 @@ ipcp_lattice<valtype>::add_value (valtype newval, cgraph_edge *cs,
+ /* A helper function that returns result of operation specified by OPCODE on
+    the value of SRC_VAL.  If non-NULL, OPND1_TYPE is expected type for the
+    value of SRC_VAL.  If the operation is binary, OPND2 is a constant value
+-   acting as its second operand.  If non-NULL, RES_TYPE is expected type of
+-   the result.  */
++   acting as its second operand.  */
+ 
+ static tree
+ get_val_across_arith_op (enum tree_code opcode,
+ 			 tree opnd1_type,
+ 			 tree opnd2,
+-			 ipcp_value<tree> *src_val,
+-			 tree res_type)
++			 ipcp_value<tree> *src_val)
+ {
+   tree opnd1 = src_val->value;
+ 
+@@ -2137,7 +2126,7 @@ get_val_across_arith_op (enum tree_code opcode,
+       && !useless_type_conversion_p (opnd1_type, TREE_TYPE (opnd1)))
+     return NULL_TREE;
+ 
+-  return ipa_get_jf_arith_result (opcode, opnd1, opnd2, res_type);
++  return ipa_get_jf_arith_result (opcode, opnd1, opnd2, NULL_TREE);
+ }
+ 
+ /* Propagate values through an arithmetic transformation described by a jump
+@@ -2213,7 +2202,7 @@ propagate_vals_across_arith_jfunc (cgraph_edge *cs,
+ 	  for (int j = 1; j < max_recursive_depth; j++)
+ 	    {
+ 	      tree cstval = get_val_across_arith_op (opcode, opnd1_type, opnd2,
+-						     src_val, res_type);
++						     src_val);
+ 	      cstval = ipacp_value_safe_for_type (res_type, cstval);
+ 	      if (!cstval)
+ 		break;
+@@ -2238,7 +2227,7 @@ propagate_vals_across_arith_jfunc (cgraph_edge *cs,
+ 	  }
+ 
+ 	tree cstval = get_val_across_arith_op (opcode, opnd1_type, opnd2,
+-					       src_val, res_type);
++					       src_val);
+ 	cstval = ipacp_value_safe_for_type (res_type, cstval);
+ 	if (cstval)
+ 	  ret |= dest_lat->add_value (cstval, cs, src_val, src_idx,
+@@ -2261,6 +2250,7 @@ propagate_vals_across_pass_through (cgraph_edge *cs, ipa_jump_func *jfunc,
+ 				    ipcp_lattice<tree> *dest_lat, int src_idx,
+ 				    tree parm_type)
+ {
++  gcc_checking_assert (parm_type);
+   return propagate_vals_across_arith_jfunc (cs,
+ 				ipa_get_jf_pass_through_operation (jfunc),
+ 				NULL_TREE,
+diff --git a/gcc/testsuite/gcc.dg/ipa/ipa-notypes-1.c b/gcc/testsuite/gcc.dg/ipa/ipa-notypes-1.c
+new file mode 100644
+index 000000000000..e8f4adaed171
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/ipa/ipa-notypes-1.c
+@@ -0,0 +1,17 @@
++/* { dg-do compile } */
++/* { dg-options "-O2" } */
++
++void some_memcpy(void *, long);
++long bufused;
++char buf, otest_s;
++void otest(...) {
++  long slength;
++  some_memcpy(&buf + bufused, slength & otest_s);
++}
++int f, finish_root_table_fli2_1;
++static void finish_root_table(char *lastname) {
++  for (;;)
++    if (finish_root_table_fli2_1)
++      otest(f, lastname);
++}
++void write_roots() { finish_root_table(""); }
+diff --git a/gcc/testsuite/gcc.dg/ipa/pr118097.c b/gcc/testsuite/gcc.dg/ipa/pr118097.c
+new file mode 100644
+index 000000000000..772e83f3bf49
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/ipa/pr118097.c
+@@ -0,0 +1,23 @@
++/* { dg-do run } */
++/* { dg-options "-O2 -fno-inline" } */
++
++int a, b, c, *d = &a;
++long e;
++static long am (long f, int g) {
++  return g == 0 || f == 1 && g == 1 ?: f / g;
++}
++static void aq (unsigned f)
++{
++  c ^= e = am(~f, 1);
++  b = 7 - (e >= 1) - 33;
++  *d = b;
++}
++
++int main() {
++  //  am(1, 1);
++  aq(1);
++  if (a == 0xffffffffffffffe5)
++    ;
++  else
++    __builtin_abort();
++}
+diff --git a/gcc/testsuite/gcc.dg/ipa/pr118535.c b/gcc/testsuite/gcc.dg/ipa/pr118535.c
+new file mode 100644
+index 000000000000..960ba4a5db2a
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/ipa/pr118535.c
+@@ -0,0 +1,17 @@
++/* { dg-do run } */
++/* { dg-options "-O2" } */
++
++int a, b, c, d, e, f, *g = &b;
++static int h(int i) { return i < 0 || i > a ? 0 : i << a; }
++static int j(unsigned short i) {
++  f = d == e;
++  *g = h(65535 ^ i);
++  return c;
++}
++int main() {
++  j(0);
++  h(0);
++  if (b != 0)
++    __builtin_abort();
++  return 0;
++}
+
+base-commit: 7d8e8f89732b1f13752e1b370852c7bcbbbde259
+-- 
+2.48.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index bac4f3e..c59978d 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 45	????
 
 	U 09_all_esysroot.patch
+	+ 81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
 
 44	2 February 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-02-09 23:58 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-02-09 23:58 UTC (permalink / raw
  To: gentoo-commits
commit:     dfe9adc6b410ac6108b25f2e7a904e8bf286ebb2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Feb  9 23:57:49 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Feb  9 23:57:57 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=dfe9adc6
15.0.0: cut patchset 45
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index c59978d..ac36710 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-45	????
+45	9 February 2025
 
 	U 09_all_esysroot.patch
 	+ 81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-02-10 21:22 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-02-10 21:22 UTC (permalink / raw
  To: gentoo-commits
commit:     1240e2dfcd8257243dfbe473fc934fa18482b91b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Feb 10 21:21:55 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Feb 10 21:21:55 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=1240e2df
15.0.0: drop upstream ipa-cp patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...orm-operations-in-the-appropriate-types-P.patch | 271 ---------------------
 15.0.0/gentoo/README.history                       |   4 +
 2 files changed, 4 insertions(+), 271 deletions(-)
diff --git a/15.0.0/gentoo/81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch b/15.0.0/gentoo/81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
deleted file mode 100644
index 165793d..0000000
--- a/15.0.0/gentoo/81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
+++ /dev/null
@@ -1,271 +0,0 @@
-From 70951aa9a0c324893d957da614fcc8c749571a52 Mon Sep 17 00:00:00 2001
-Message-ID: <70951aa9a0c324893d957da614fcc8c749571a52.1738971381.git.sam@gentoo.org>
-From: Martin Jambor <mjambor@suse.cz>
-Date: Wed, 22 Jan 2025 17:44:48 +0100
-Subject: [PATCH] ipa-cp: Perform operations in the appropriate types (PR
- 118097)
-
-Hi,
-
-one of the testcases from PR 118097 and the one from PR 118535 show
-that the fix to PR 118138 was incomplete.  We must not only make sure
-that (intermediate) results of operations performed by IPA-CP are
-fold_converted to the type of the destination formal parameter but we
-also must decouple the these types from the ones in which operations
-are performed.
-
-This patch does that, even though we do not store or stream the
-operation types, instead we simply limit ourselves to tcc_comparisons
-and operations for which the first operand and the result are of the
-same type as determined by expr_type_first_operand_type_p.  If we
-wanted to go beyond these, we would indeed need to store/stream the
-respective operation type.
-
-ipa_value_from_jfunc needs an additional check that res_type is not
-NULL because it is not called just from within IPA-CP (where we know
-we have a destination lattice slot belonging to a defined parameter)
-but also from inlining, ipa-fnsummary and ipa-modref where it is used
-to examine a call to a function with variadic arguments and we do not
-have types for the unknown parameters.  But we cannot really work with
-those or estimate any benefits when it comes to them, so ignoring them
-should be OK.
-
-Even after this patch, ipa_get_jf_arith_result has a parameter called
-res_type in which it performs operations for aggregate jump functions,
-where we do not allow type conversions when constucting the jump
-functions and the type is the type of the stored data.  In GCC 16, we
-could relax this and allow conversions like for scalars.
-
-Bootstrapped, LTO-bootstrapped and tested on x86_64-linux.  OK for
-master?
-
-Thanks,
-
-Honza
-
-gcc/ChangeLog:
-
-2025-01-20  Martin Jambor  <mjambor@suse.cz>
-
-	PR ipa/118097
-	* ipa-cp.cc (ipa_get_jf_arith_result): Adjust comment.
-	(ipa_get_jf_pass_through_result): Removed.
-	(ipa_value_from_jfunc): Use directly ipa_get_jf_arith_result, do
-	not specify operation type but make sure we check and possibly
-	convert the result.
-	(get_val_across_arith_op): Remove the last parameter, always pass
-	NULL_TREE to ipa_get_jf_arith_result in its last argument.
-	(propagate_vals_across_arith_jfunc): Do not pass res_type to
-	get_val_across_arith_op.
-	(propagate_vals_across_pass_through): Add checking assert that
-	parm_type is not NULL.
-
-gcc/testsuite/ChangeLog:
-
-2025-01-20  Martin Jambor  <mjambor@suse.cz>
-
-PR ipa/118097
-	* gcc.dg/ipa/pr118097.c: New test.
-	* gcc.dg/ipa/pr118535.c: Likewise.
-	* gcc.dg/ipa/ipa-notypes-1.c: Likewise.
----
- gcc/ipa-cp.cc                            | 46 ++++++++++--------------
- gcc/testsuite/gcc.dg/ipa/ipa-notypes-1.c | 17 +++++++++
- gcc/testsuite/gcc.dg/ipa/pr118097.c      | 23 ++++++++++++
- gcc/testsuite/gcc.dg/ipa/pr118535.c      | 17 +++++++++
- 4 files changed, 75 insertions(+), 28 deletions(-)
- create mode 100644 gcc/testsuite/gcc.dg/ipa/ipa-notypes-1.c
- create mode 100644 gcc/testsuite/gcc.dg/ipa/pr118097.c
- create mode 100644 gcc/testsuite/gcc.dg/ipa/pr118535.c
-
-diff --git a/gcc/ipa-cp.cc b/gcc/ipa-cp.cc
-index d89324a00775..68959f2677ba 100644
---- a/gcc/ipa-cp.cc
-+++ b/gcc/ipa-cp.cc
-@@ -1467,11 +1467,10 @@ ipacp_value_safe_for_type (tree param_type, tree value)
-     return NULL_TREE;
- }
- 
--/* Return the result of a (possibly arithmetic) operation on the constant
--   value INPUT.  OPERAND is 2nd operand for binary operation.  RES_TYPE is
--   the type of the parameter to which the result is passed.  Return
--   NULL_TREE if that cannot be determined or be considered an
--   interprocedural invariant.  */
-+/* Return the result of a (possibly arithmetic) operation on the constant value
-+   INPUT.  OPERAND is 2nd operand for binary operation.  RES_TYPE is the type
-+   in which any operation is to be performed.  Return NULL_TREE if that cannot
-+   be determined or be considered an interprocedural invariant.  */
- 
- static tree
- ipa_get_jf_arith_result (enum tree_code opcode, tree input, tree operand,
-@@ -1513,21 +1512,6 @@ ipa_get_jf_arith_result (enum tree_code opcode, tree input, tree operand,
-   return res;
- }
- 
--/* Return the result of a (possibly arithmetic) pass through jump function
--   JFUNC on the constant value INPUT.  RES_TYPE is the type of the parameter
--   to which the result is passed.  Return NULL_TREE if that cannot be
--   determined or be considered an interprocedural invariant.  */
--
--static tree
--ipa_get_jf_pass_through_result (struct ipa_jump_func *jfunc, tree input,
--				tree res_type)
--{
--  return ipa_get_jf_arith_result (ipa_get_jf_pass_through_operation (jfunc),
--				  input,
--				  ipa_get_jf_pass_through_operand (jfunc),
--				  res_type);
--}
--
- /* Return the result of an ancestor jump function JFUNC on the constant value
-    INPUT.  Return NULL_TREE if that cannot be determined.  */
- 
-@@ -1595,7 +1579,14 @@ ipa_value_from_jfunc (class ipa_node_params *info, struct ipa_jump_func *jfunc,
- 	return NULL_TREE;
- 
-       if (jfunc->type == IPA_JF_PASS_THROUGH)
--	return ipa_get_jf_pass_through_result (jfunc, input, parm_type);
-+	{
-+	  if (!parm_type)
-+	    return NULL_TREE;
-+	  enum tree_code opcode = ipa_get_jf_pass_through_operation (jfunc);
-+	  tree op2 = ipa_get_jf_pass_through_operand (jfunc);
-+	  tree cstval = ipa_get_jf_arith_result (opcode, input, op2, NULL_TREE);
-+	  return ipacp_value_safe_for_type (parm_type, cstval);
-+	}
-       else
- 	return ipa_get_jf_ancestor_result (jfunc, input);
-     }
-@@ -2120,15 +2111,13 @@ ipcp_lattice<valtype>::add_value (valtype newval, cgraph_edge *cs,
- /* A helper function that returns result of operation specified by OPCODE on
-    the value of SRC_VAL.  If non-NULL, OPND1_TYPE is expected type for the
-    value of SRC_VAL.  If the operation is binary, OPND2 is a constant value
--   acting as its second operand.  If non-NULL, RES_TYPE is expected type of
--   the result.  */
-+   acting as its second operand.  */
- 
- static tree
- get_val_across_arith_op (enum tree_code opcode,
- 			 tree opnd1_type,
- 			 tree opnd2,
--			 ipcp_value<tree> *src_val,
--			 tree res_type)
-+			 ipcp_value<tree> *src_val)
- {
-   tree opnd1 = src_val->value;
- 
-@@ -2137,7 +2126,7 @@ get_val_across_arith_op (enum tree_code opcode,
-       && !useless_type_conversion_p (opnd1_type, TREE_TYPE (opnd1)))
-     return NULL_TREE;
- 
--  return ipa_get_jf_arith_result (opcode, opnd1, opnd2, res_type);
-+  return ipa_get_jf_arith_result (opcode, opnd1, opnd2, NULL_TREE);
- }
- 
- /* Propagate values through an arithmetic transformation described by a jump
-@@ -2213,7 +2202,7 @@ propagate_vals_across_arith_jfunc (cgraph_edge *cs,
- 	  for (int j = 1; j < max_recursive_depth; j++)
- 	    {
- 	      tree cstval = get_val_across_arith_op (opcode, opnd1_type, opnd2,
--						     src_val, res_type);
-+						     src_val);
- 	      cstval = ipacp_value_safe_for_type (res_type, cstval);
- 	      if (!cstval)
- 		break;
-@@ -2238,7 +2227,7 @@ propagate_vals_across_arith_jfunc (cgraph_edge *cs,
- 	  }
- 
- 	tree cstval = get_val_across_arith_op (opcode, opnd1_type, opnd2,
--					       src_val, res_type);
-+					       src_val);
- 	cstval = ipacp_value_safe_for_type (res_type, cstval);
- 	if (cstval)
- 	  ret |= dest_lat->add_value (cstval, cs, src_val, src_idx,
-@@ -2261,6 +2250,7 @@ propagate_vals_across_pass_through (cgraph_edge *cs, ipa_jump_func *jfunc,
- 				    ipcp_lattice<tree> *dest_lat, int src_idx,
- 				    tree parm_type)
- {
-+  gcc_checking_assert (parm_type);
-   return propagate_vals_across_arith_jfunc (cs,
- 				ipa_get_jf_pass_through_operation (jfunc),
- 				NULL_TREE,
-diff --git a/gcc/testsuite/gcc.dg/ipa/ipa-notypes-1.c b/gcc/testsuite/gcc.dg/ipa/ipa-notypes-1.c
-new file mode 100644
-index 000000000000..e8f4adaed171
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/ipa/ipa-notypes-1.c
-@@ -0,0 +1,17 @@
-+/* { dg-do compile } */
-+/* { dg-options "-O2" } */
-+
-+void some_memcpy(void *, long);
-+long bufused;
-+char buf, otest_s;
-+void otest(...) {
-+  long slength;
-+  some_memcpy(&buf + bufused, slength & otest_s);
-+}
-+int f, finish_root_table_fli2_1;
-+static void finish_root_table(char *lastname) {
-+  for (;;)
-+    if (finish_root_table_fli2_1)
-+      otest(f, lastname);
-+}
-+void write_roots() { finish_root_table(""); }
-diff --git a/gcc/testsuite/gcc.dg/ipa/pr118097.c b/gcc/testsuite/gcc.dg/ipa/pr118097.c
-new file mode 100644
-index 000000000000..772e83f3bf49
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/ipa/pr118097.c
-@@ -0,0 +1,23 @@
-+/* { dg-do run } */
-+/* { dg-options "-O2 -fno-inline" } */
-+
-+int a, b, c, *d = &a;
-+long e;
-+static long am (long f, int g) {
-+  return g == 0 || f == 1 && g == 1 ?: f / g;
-+}
-+static void aq (unsigned f)
-+{
-+  c ^= e = am(~f, 1);
-+  b = 7 - (e >= 1) - 33;
-+  *d = b;
-+}
-+
-+int main() {
-+  //  am(1, 1);
-+  aq(1);
-+  if (a == 0xffffffffffffffe5)
-+    ;
-+  else
-+    __builtin_abort();
-+}
-diff --git a/gcc/testsuite/gcc.dg/ipa/pr118535.c b/gcc/testsuite/gcc.dg/ipa/pr118535.c
-new file mode 100644
-index 000000000000..960ba4a5db2a
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/ipa/pr118535.c
-@@ -0,0 +1,17 @@
-+/* { dg-do run } */
-+/* { dg-options "-O2" } */
-+
-+int a, b, c, d, e, f, *g = &b;
-+static int h(int i) { return i < 0 || i > a ? 0 : i << a; }
-+static int j(unsigned short i) {
-+  f = d == e;
-+  *g = h(65535 ^ i);
-+  return c;
-+}
-+int main() {
-+  j(0);
-+  h(0);
-+  if (b != 0)
-+    __builtin_abort();
-+  return 0;
-+}
-
-base-commit: 7d8e8f89732b1f13752e1b370852c7bcbbbde259
--- 
-2.48.1
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index ac36710..be23e46 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+46	????
+
+	- 81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
+
 45	9 February 2025
 
 	U 09_all_esysroot.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-02-12 15:12 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-02-12 15:12 UTC (permalink / raw
  To: gentoo-commits
commit:     2f8447a89b5426413f54aa0153448c0e1c45a4c8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Feb 12 15:11:48 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Feb 12 15:11:48 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=2f8447a8
15.0.0: add C++ patch
Fixes MariaDB build. I'll likely backport this to the last snapshot
along with the coro fixes once it gets merged upstream.
Bug: https://gcc.gnu.org/PR118822
Bug: https://bugs.gentoo.org/949573
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...gressions-caused-by-for-while-loops-with-.patch | 562 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 563 insertions(+)
diff --git a/15.0.0/gentoo/81_all_PR118822-c-Fix-up-regressions-caused-by-for-while-loops-with-.patch b/15.0.0/gentoo/81_all_PR118822-c-Fix-up-regressions-caused-by-for-while-loops-with-.patch
new file mode 100644
index 0000000..cc1a3d6
--- /dev/null
+++ b/15.0.0/gentoo/81_all_PR118822-c-Fix-up-regressions-caused-by-for-while-loops-with-.patch
@@ -0,0 +1,562 @@
+From 94063edfaf24b3bd9ef392e2eefc6bc6f7fcfbab Mon Sep 17 00:00:00 2001
+Message-ID: <94063edfaf24b3bd9ef392e2eefc6bc6f7fcfbab.1739372825.git.sam@gentoo.org>
+From: Jakub Jelinek <jakub@redhat.com>
+Date: Tue, 11 Feb 2025 18:59:50 +0100
+Subject: [PATCH] c++: Fix up regressions caused by for/while loops with
+ declarations [PR118822]
+
+Hi!
+
+The recent PR86769 r15-7426 changes regressed the following two testcases,
+the first one is more important as it is derived from real-world code.
+
+The first problem is that the chosen
+prep = do_pushlevel (sk_block);
+// emit something
+body = push_stmt_list ();
+// emit further stuff
+body = pop_stmt_list (body);
+prep = do_poplevel (prep);
+way of constructing the {FOR,WHILE}_COND_PREP and {FOR,WHILE}_BODY
+isn't reliable.  If during parsing a label is seen in the body and then
+some decl with destructors, sk_cleanup transparent scope is added, but
+the correspondiong result from push_stmt_list is saved in
+*current_binding_level and pop_stmt_list then pops even that statement list
+but only do_poplevel actually attempts to pop the sk_cleanup scope and so we
+ICE.
+The reason for not doing do_pushlevel (sk_block); do_pushlevel (sk_block);
+is that variables should be in the same scope (otherwise various e.g.
+redeclaration*.C tests FAIL) and doing do_pushlevel (sk_block); do_pushlevel
+(sk_cleanup); wouldn't work either as do_poplevel would silently unwind even
+the cleanup one.
+
+The second problem is that my assumption that the declaration in the
+condition will have zero or one cleanup is just wrong, at least for
+structured bindings used as condition, there can be as many cleanups as
+there are names in the binding + 1.
+
+So, the following patch changes the earlier approach.  Nothing is removed
+from the {FOR,WHILE}_COND_PREP subtrees while doing adjust_loop_decl_cond,
+push_stmt_list isn't called either; all it does is remember as an integer
+the number of cleanups (CLEANUP_STMT at the end of the STATEMENT_LISTs)
+from querying stmt_list_stack and finding the initial *body_p in there
+(that integer is stored into {FOR,WHILE}_COND_CLEANUP), and temporarily
+{FOR,WHILE}_BODY is set to the last statement (if any) in the innermost
+STATEMENT_LIST at the adjust_loop_decl_cond time; then at
+finish_{for,while}_stmt a new finish_loop_cond_prep routine takes care of
+do_poplevel for the scope (which is in {FOR,WHILE}_COND_PREP) and finds
+given {FOR,WHILE}_COND_CLEANUP number and {FOR,WHILE}_BODY tree the right
+spot where body statements start and moves that into {FOR,WHILE}_BODY.
+Finally genericize_c_loop then inserts the cond, body, continue label, expr
+into the right subtree of {FOR,WHILE}_COND_PREP.
+The constexpr evaluation unfortunately had to be changed as well, because
+we don't want to evaluate everything in BIND_EXPR_BODY (*_COND_PREP ())
+right away, we want to evaluate it with the exception of the CLEANUP_STMT
+cleanups at the end (given {FOR,WHILE}_COND_CLEANUP levels), and defer
+the evaluation of the cleanups until after cond, body, expr are evaluated.
+
+Bootstrapped/regtested on x86_64-linux and i686-linux, ok for trunk?
+
+2025-02-11  Jakub Jelinek  <jakub@redhat.com>
+
+	PR c++/118822
+	PR c++/118833
+gcc/c-family/
+	* c-common.h (WHILE_COND_CLEANUP): Change description in comment.
+	(FOR_COND_CLEANUP): Likewise.
+	* c-gimplify.cc (genericize_c_loop): Adjust for COND_CLEANUP
+	being CLEANUP_STMT/TRY_FINALLY_EXPR trailing nesting depth
+	instead of actual cleanup.
+gcc/cp/
+	* semantics.cc (adjust_loop_decl_cond): Allow multiple trailing
+	CLEANUP_STMT levels in *BODY_P.  Set *CLEANUP_P to the number
+	of levels rather than one particular cleanup, keep the cleanups
+	in *PREP_P.  Set *BODY_P to the last stmt in the cur_stmt_list
+	or NULL if *CLEANUP_P and the innermost cur_stmt_list is empty.
+	(finish_loop_cond_prep): New function.
+	(finish_while_stmt, finish_for_stmt): Use it.  Don't call
+	set_one_cleanup_loc.
+	* constexpr.cc (cxx_eval_loop_expr): Adjust handling of
+	{FOR,WHILE}_COND_{PREP,CLEANUP}.
+gcc/testsuite/
+	* g++.dg/expr/for9.C: New test.
+	* g++.dg/cpp26/decomp12.C: New test.
+---
+ gcc/c-family/c-common.h               |   6 +-
+ gcc/c-family/c-gimplify.cc            |  41 +++-----
+ gcc/cp/constexpr.cc                   |  83 ++++++++++++++--
+ gcc/cp/semantics.cc                   | 135 +++++++++++++++++++-------
+ gcc/testsuite/g++.dg/cpp26/decomp12.C |  46 +++++++++
+ gcc/testsuite/g++.dg/expr/for9.C      |  25 +++++
+ 6 files changed, 267 insertions(+), 69 deletions(-)
+ create mode 100644 gcc/testsuite/g++.dg/cpp26/decomp12.C
+ create mode 100644 gcc/testsuite/g++.dg/expr/for9.C
+
+diff --git a/gcc/c-family/c-common.h b/gcc/c-family/c-common.h
+index bc238430b7a7..ea6c29750567 100644
+--- a/gcc/c-family/c-common.h
++++ b/gcc/c-family/c-common.h
+@@ -1518,7 +1518,8 @@ extern tree build_userdef_literal (tree suffix_id, tree value,
+ 
+ /* WHILE_STMT accessors.  These give access to the condition of the
+    while statement, the body, and name of the while statement, and
+-   condition preparation statements and its cleanup, respectively.  */
++   condition preparation statements and number of its nested cleanups,
++   respectively.  */
+ #define WHILE_COND(NODE)	TREE_OPERAND (WHILE_STMT_CHECK (NODE), 0)
+ #define WHILE_BODY(NODE)	TREE_OPERAND (WHILE_STMT_CHECK (NODE), 1)
+ #define WHILE_NAME(NODE)	TREE_OPERAND (WHILE_STMT_CHECK (NODE), 2)
+@@ -1533,7 +1534,8 @@ extern tree build_userdef_literal (tree suffix_id, tree value,
+ 
+ /* FOR_STMT accessors.  These give access to the init statement,
+    condition, update expression, body and name of the for statement,
+-   and condition preparation statements and its cleanup, respectively.  */
++   and condition preparation statements and number of its nested cleanups,
++   respectively.  */
+ #define FOR_INIT_STMT(NODE)	TREE_OPERAND (FOR_STMT_CHECK (NODE), 0)
+ #define FOR_COND(NODE)		TREE_OPERAND (FOR_STMT_CHECK (NODE), 1)
+ #define FOR_EXPR(NODE)		TREE_OPERAND (FOR_STMT_CHECK (NODE), 2)
+diff --git a/gcc/c-family/c-gimplify.cc b/gcc/c-family/c-gimplify.cc
+index d53e0c2dc567..dc5e80dfa6be 100644
+--- a/gcc/c-family/c-gimplify.cc
++++ b/gcc/c-family/c-gimplify.cc
+@@ -258,8 +258,10 @@ expr_loc_or_loc (const_tree expr, location_t or_loc)
+    for C++ for/while loops with variable declaration as condition.  COND_PREP
+    is a BIND_EXPR with the declaration and initialization of the condition
+    variable, into which COND, BODY, continue label if needed and INCR if
+-   non-NULL should be appended, and COND_CLEANUP are statements which should
+-   be evaluated after that or if anything in COND, BODY or INCR throws.  */
++   non-NULL should be appended, and COND_CLEANUP is number of nested
++   CLEANUP_STMT -> TRY_FINALLY_EXPR statements at the end.  If non-NULL,
++   COND, BODY, continue label if needed and INCR if non-NULL should be
++   appended to the body of the COND_CLEANUP's nested TRY_FINALLY_EXPR.  */
+ 
+ static void
+ genericize_c_loop (tree *stmt_p, location_t start_locus, tree cond, tree body,
+@@ -278,7 +280,6 @@ genericize_c_loop (tree *stmt_p, location_t start_locus, tree cond, tree body,
+   walk_tree_1 (&cond_prep, func, data, NULL, lh);
+   walk_tree_1 (&cond, func, data, NULL, lh);
+   walk_tree_1 (&incr, func, data, NULL, lh);
+-  walk_tree_1 (&cond_cleanup, func, data, NULL, lh);
+ 
+   blab = begin_bc_block (bc_break, start_locus);
+   clab = begin_bc_block (bc_continue, start_locus);
+@@ -309,36 +310,24 @@ genericize_c_loop (tree *stmt_p, location_t start_locus, tree cond, tree body,
+ 	 EXPR;
+ 	 goto top;
+ 
+-	 or
+-
+-	 try {
+-	   if (COND); else break;
+-	   BODY;
+-	   cont:
+-	   EXPR;
+-	 } finally {
+-	   COND_CLEANUP
+-	 }
+-
+-	 appended into COND_PREP body.  */
++	 appended into COND_PREP body or body of some TRY_FINALLY_EXPRs
++	 at the end of COND_PREP.  */
+       gcc_assert (cond_is_first && TREE_CODE (cond_prep) == BIND_EXPR);
+       tree top = build1 (LABEL_EXPR, void_type_node,
+ 			 create_artificial_label (start_locus));
+       exit = build1 (GOTO_EXPR, void_type_node, LABEL_EXPR_LABEL (top));
+       append_to_statement_list (top, &outer_stmt_list);
+       append_to_statement_list (cond_prep, &outer_stmt_list);
+-      stmt_list = BIND_EXPR_BODY (cond_prep);
+-      BIND_EXPR_BODY (cond_prep) = NULL_TREE;
+       stmt_list_p = &BIND_EXPR_BODY (cond_prep);
+-      if (cond_cleanup && TREE_SIDE_EFFECTS (cond_cleanup))
+-	{
+-	  t = build2_loc (EXPR_LOCATION (cond_cleanup), TRY_FINALLY_EXPR,
+-			  void_type_node, NULL_TREE, cond_cleanup);
+-	  append_to_statement_list (t, &stmt_list);
+-	  *stmt_list_p = stmt_list;
+-	  stmt_list_p = &TREE_OPERAND (t, 0);
+-	  stmt_list = NULL_TREE;
+-	}
++      if (cond_cleanup)
++	for (unsigned depth = tree_to_uhwi (cond_cleanup); depth; --depth)
++	  {
++	    t = tsi_stmt (tsi_last (*stmt_list_p));
++	    gcc_assert (TREE_CODE (t) == TRY_FINALLY_EXPR);
++	    stmt_list_p = &TREE_OPERAND (t, 0);
++	  }
++      stmt_list = *stmt_list_p;
++      *stmt_list_p = NULL_TREE;
+       tree after_cond = create_artificial_label (cond_locus);
+       tree goto_after_cond = build1 (GOTO_EXPR, void_type_node, after_cond);
+       t = build1 (GOTO_EXPR, void_type_node, get_bc_label (bc_break));
+diff --git a/gcc/cp/constexpr.cc b/gcc/cp/constexpr.cc
+index f142dd32bc80..bb012d9d8f0b 100644
+--- a/gcc/cp/constexpr.cc
++++ b/gcc/cp/constexpr.cc
+@@ -7153,6 +7153,7 @@ cxx_eval_loop_expr (const constexpr_ctx *ctx, tree t,
+ 
+   tree body, cond = NULL_TREE, expr = NULL_TREE;
+   tree cond_prep = NULL_TREE, cond_cleanup = NULL_TREE;
++  unsigned cond_cleanup_depth = 0;
+   int count = 0;
+   switch (TREE_CODE (t))
+     {
+@@ -7188,11 +7189,25 @@ cxx_eval_loop_expr (const constexpr_ctx *ctx, tree t,
+     }
+   if (cond_prep)
+     gcc_assert (TREE_CODE (cond_prep) == BIND_EXPR);
+-  auto cleanup_cond = [=] {
++  auto cleanup_cond = [=, &cond_cleanup_depth] {
+     /* Clean up the condition variable after each iteration.  */
+-    if (cond_cleanup && !*non_constant_p)
+-      cxx_eval_constant_expression (ctx, cond_cleanup, vc_discard,
+-				    non_constant_p, overflow_p);
++    if (cond_cleanup_depth && !*non_constant_p)
++      {
++	auto_vec<tree, 4> cleanups (cond_cleanup_depth);
++	tree s = BIND_EXPR_BODY (cond_prep);
++	unsigned i;
++	for (i = cond_cleanup_depth; i; --i)
++	  {
++	    tree_stmt_iterator iter = tsi_last (s);
++	    s = tsi_stmt (iter);
++	    cleanups.quick_push (CLEANUP_EXPR (s));
++	    s = CLEANUP_BODY (s);
++	  }
++	tree c;
++	FOR_EACH_VEC_ELT_REVERSE (cleanups, i, c)
++	  cxx_eval_constant_expression (ctx, c, vc_discard, non_constant_p,
++					overflow_p);
++      }
+     if (cond_prep)
+       for (tree decl = BIND_EXPR_VARS (cond_prep);
+ 	   decl; decl = DECL_CHAIN (decl))
+@@ -7227,9 +7242,63 @@ cxx_eval_loop_expr (const constexpr_ctx *ctx, tree t,
+ 	  for (tree decl = BIND_EXPR_VARS (cond_prep);
+ 	       decl; decl = DECL_CHAIN (decl))
+ 	    ctx->global->clear_value (decl);
+-	  cxx_eval_constant_expression (ctx, BIND_EXPR_BODY (cond_prep),
+-					vc_discard, non_constant_p,
+-					overflow_p, jump_target);
++	  if (cond_cleanup)
++	    {
++	      /* If COND_CLEANUP is non-NULL, we need to evaluate DEPTH
++		 nested STATEMENT_EXPRs from inside of BIND_EXPR_BODY,
++		 but defer the evaluation of CLEANUP_EXPRs at the end
++		 of those STATEMENT_EXPRs.  */
++	      cond_cleanup_depth = 0;
++	      tree s = BIND_EXPR_BODY (cond_prep);
++	      for (unsigned depth = tree_to_uhwi (cond_cleanup);
++		   depth; --depth)
++		{
++		  for (tree_stmt_iterator i = tsi_start (s);
++		       !tsi_end_p (i); ++i)
++		    {
++		      tree stmt = *i;
++		      if (TREE_CODE (stmt) == DEBUG_BEGIN_STMT)
++			continue;
++		      if (tsi_one_before_end_p (i))
++			{
++			  gcc_assert (TREE_CODE (stmt) == CLEANUP_STMT);
++			  if (*jump_target)
++			    {
++			      depth = 1;
++			      break;
++			    }
++			  ++cond_cleanup_depth;
++			  if (depth > 1)
++			    {
++			      s = CLEANUP_BODY (stmt);
++			      break;
++			    }
++			  cxx_eval_constant_expression (ctx,
++							CLEANUP_BODY (stmt),
++							vc_discard,
++							non_constant_p,
++							overflow_p,
++							jump_target);
++			  break;
++			}
++		      cxx_eval_constant_expression (ctx, stmt, vc_discard,
++						    non_constant_p, overflow_p,
++						    jump_target);
++		      if (*non_constant_p
++			  || returns (jump_target)
++			  || breaks (jump_target)
++			  || continues (jump_target))
++			{
++			  depth = 1;
++			  break;
++			}
++		    }
++		}
++	    }
++	  else
++	    cxx_eval_constant_expression (ctx, BIND_EXPR_BODY (cond_prep),
++					  vc_discard, non_constant_p,
++					  overflow_p, jump_target);
+ 	}
+ 
+       if (cond)
+diff --git a/gcc/cp/semantics.cc b/gcc/cp/semantics.cc
+index 8a2d86576fb0..2c3859e457ed 100644
+--- a/gcc/cp/semantics.cc
++++ b/gcc/cp/semantics.cc
+@@ -790,8 +790,8 @@ finish_cond (tree *cond_p, tree expr)
+ 	    while (A x = 42) { }
+ 	    for (; A x = 42;) { }
+    move the *BODY_P statements as a BIND_EXPR into {FOR,WHILE}_COND_PREP
+-   and if there is any CLEANUP_STMT at the end, remove that and
+-   put the cleanup into {FOR,WHILE}_COND_CLEANUP.
++   and if there are any CLEANUP_STMT at the end, remember their count in
++   {FOR,WHILE}_COND_CLEANUP.
+    genericize_c_loop will then handle it appropriately.  In particular,
+    the {FOR,WHILE}_COND, {FOR,WHILE}_BODY, if used continue label and
+    FOR_EXPR will be appended into the {FOR,WHILE}_COND_PREP BIND_EXPR,
+@@ -807,26 +807,95 @@ adjust_loop_decl_cond (tree *body_p, tree *prep_p, tree *cleanup_p)
+     return;
+ 
+   gcc_assert (!processing_template_decl);
+-  if (*body_p != cur_stmt_list)
+-    {
+-      /* There can be either no cleanup at all, if the condition
+-	 declaration doesn't have non-trivial destructor, or a single
+-	 one if it does.  In that case extract it into *CLEANUP_P.  */
+-      gcc_assert (stmt_list_stack->length () > 1
+-		  && (*stmt_list_stack)[stmt_list_stack->length ()
+-					- 2] == *body_p);
+-      tree_stmt_iterator last = tsi_last (*body_p);
+-      gcc_assert (tsi_one_before_end_p (last)
+-		  && TREE_CODE (tsi_stmt (last)) == CLEANUP_STMT
+-		  && CLEANUP_BODY (tsi_stmt (last)) == cur_stmt_list
+-		  && tsi_end_p (tsi_last (cur_stmt_list))
+-		  && !CLEANUP_EH_ONLY (tsi_stmt (last)));
+-      *cleanup_p = CLEANUP_EXPR (tsi_stmt (last));
+-      tsi_delink (&last);
++  *prep_p = *body_p;
++  if (*prep_p != cur_stmt_list)
++    {
++      /* There can be just one CLEANUP_STMT, or there could be multiple
++	 nested CLEANUP_STMTs, e.g. for structured bindings used as
++	 condition.  */
++      gcc_assert (stmt_list_stack->length () > 1);
++      for (unsigned i = stmt_list_stack->length () - 2; ; --i)
++	{
++	  tree t = (*stmt_list_stack)[i];
++	  tree_stmt_iterator last = tsi_last (t);
++	  gcc_assert (tsi_one_before_end_p (last)
++		      && TREE_CODE (tsi_stmt (last)) == CLEANUP_STMT
++		      && (CLEANUP_BODY (tsi_stmt (last))
++			  == (*stmt_list_stack)[i + 1])
++		      && !CLEANUP_EH_ONLY (tsi_stmt (last)));
++	  if (t == *prep_p)
++	    {
++	      *cleanup_p = build_int_cst (long_unsigned_type_node,
++					  stmt_list_stack->length () - 1 - i);
++	      break;
++	    }
++	  gcc_assert (i >= 1);
++	}
+     }
+   current_binding_level->keep = true;
+-  *prep_p = *body_p;
+-  *body_p = push_stmt_list ();
++  tree_stmt_iterator iter = tsi_last (cur_stmt_list);
++  if (tsi_end_p (iter))
++    *body_p = NULL_TREE;
++  else
++    *body_p = tsi_stmt (iter);
++}
++
++/* Finalize {FOR,WHILE}_{BODY,COND_PREP} after the loop body.
++   The above function initialized *BODY_P to the last statement
++   in *PREP_P at that point.
++   Call do_poplevel on *PREP_P and move everything after that
++   former last statement into *BODY_P.  genericize_c_loop
++   will later put those parts back together.
++   CLEANUP is {FOR,WHILE}_COND_CLEANUP.  */
++
++static void
++finish_loop_cond_prep (tree *body_p, tree *prep_p, tree cleanup)
++{
++  *prep_p = do_poplevel (*prep_p);
++  gcc_assert (TREE_CODE (*prep_p) == BIND_EXPR);
++  if (BIND_EXPR_BODY (*prep_p) == *body_p)
++    {
++      gcc_assert (cleanup == NULL_TREE);
++      *body_p = build_empty_stmt (input_location);
++      return;
++    }
++  gcc_assert (TREE_CODE (BIND_EXPR_BODY (*prep_p)) == STATEMENT_LIST);
++  tree stmt_list = BIND_EXPR_BODY (*prep_p);
++  if (cleanup)
++    {
++      tree_stmt_iterator iter = tsi_last (stmt_list);
++      gcc_assert (TREE_CODE (tsi_stmt (iter)) == CLEANUP_STMT);
++      for (unsigned depth = tree_to_uhwi (cleanup); depth > 1; --depth)
++	{
++	  gcc_assert (TREE_CODE (CLEANUP_BODY (tsi_stmt (iter)))
++		      == STATEMENT_LIST);
++	  iter = tsi_last (CLEANUP_BODY (tsi_stmt (iter)));
++	  gcc_assert (TREE_CODE (tsi_stmt (iter)) == CLEANUP_STMT);
++	}
++      if (*body_p == NULL_TREE)
++	{
++	  *body_p = CLEANUP_BODY (tsi_stmt (iter));
++	  CLEANUP_BODY (tsi_stmt (iter)) = build_empty_stmt (input_location);
++	  return;
++	}
++      stmt_list = CLEANUP_BODY (tsi_stmt (iter));
++    }
++  tree_stmt_iterator iter = tsi_start (stmt_list);
++  while (tsi_stmt (iter) != *body_p)
++    tsi_next (&iter);
++  if (tsi_one_before_end_p (iter))
++    *body_p = build_empty_stmt (input_location);
++  else
++    {
++      tsi_next (&iter);
++      *body_p = NULL_TREE;
++      while (!tsi_end_p (iter))
++	{
++	  tree t = tsi_stmt (iter);
++	  tsi_delink (&iter);
++	  append_to_statement_list_force (t, body_p);
++	}
++    }
+ }
+ 
+ /* Finish a goto-statement.  */
+@@ -1437,14 +1506,13 @@ void
+ finish_while_stmt (tree while_stmt)
+ {
+   end_maybe_infinite_loop (boolean_true_node);
+-  WHILE_BODY (while_stmt)
+-    = (WHILE_COND_PREP (while_stmt)
+-       ? pop_stmt_list (WHILE_BODY (while_stmt))
+-       : do_poplevel (WHILE_BODY (while_stmt)));
+-  finish_loop_cond (&WHILE_COND (while_stmt), WHILE_BODY (while_stmt));
+   if (WHILE_COND_PREP (while_stmt))
+-    WHILE_COND_PREP (while_stmt) = do_poplevel (WHILE_COND_PREP (while_stmt));
+-  set_one_cleanup_loc (WHILE_COND_CLEANUP (while_stmt), input_location);
++    finish_loop_cond_prep (&WHILE_BODY (while_stmt),
++			   &WHILE_COND_PREP (while_stmt),
++			   WHILE_COND_CLEANUP (while_stmt));
++  else
++    WHILE_BODY (while_stmt) = do_poplevel (WHILE_BODY (while_stmt));
++  finish_loop_cond (&WHILE_COND (while_stmt), WHILE_BODY (while_stmt));
+ }
+ 
+ /* Begin a do-statement.  Returns a newly created DO_STMT if
+@@ -1709,17 +1777,16 @@ finish_for_stmt (tree for_stmt)
+     RANGE_FOR_BODY (for_stmt) = do_poplevel (RANGE_FOR_BODY (for_stmt));
+   else
+     {
+-      FOR_BODY (for_stmt)
+-	= (FOR_COND_PREP (for_stmt)
+-	   ? pop_stmt_list (FOR_BODY (for_stmt))
+-	   : do_poplevel (FOR_BODY (for_stmt)));
++      if (FOR_COND_PREP (for_stmt))
++	finish_loop_cond_prep (&FOR_BODY (for_stmt),
++			       &FOR_COND_PREP (for_stmt),
++			       FOR_COND_CLEANUP (for_stmt));
++      else
++	FOR_BODY (for_stmt) = do_poplevel (FOR_BODY (for_stmt));
+       if (FOR_COND (for_stmt))
+ 	finish_loop_cond (&FOR_COND (for_stmt),
+ 			  FOR_EXPR (for_stmt) ? integer_one_node
+ 					      : FOR_BODY (for_stmt));
+-      if (FOR_COND_PREP (for_stmt))
+-	FOR_COND_PREP (for_stmt) = do_poplevel (FOR_COND_PREP (for_stmt));
+-      set_one_cleanup_loc (FOR_COND_CLEANUP (for_stmt), input_location);
+     }
+ 
+   /* Pop the scope for the body of the loop.  */
+diff --git a/gcc/testsuite/g++.dg/cpp26/decomp12.C b/gcc/testsuite/g++.dg/cpp26/decomp12.C
+new file mode 100644
+index 000000000000..c4f56aa5f6ad
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/cpp26/decomp12.C
+@@ -0,0 +1,46 @@
++// P0963R3 - Structured binding declaration as a condition
++// { dg-do compile { target c++11 } }
++// { dg-options "" }
++
++namespace std {
++  template<typename T> struct tuple_size;
++  template<int, typename> struct tuple_element;
++}
++
++struct S {
++  S () : s (0) {}
++  S (int x) : s (x) {}
++  S (const S &x) : s (x.s) {}
++  ~S () {}
++  int s;
++};
++
++struct T {
++  S a, b, c;
++  ~T () {}
++  explicit operator bool () const noexcept { return a.s == b.s; }
++  template <int I> S get () { return I ? a : b; }
++};
++
++template<> struct std::tuple_size<T> { static const int value = 2; };
++template<int I> struct std::tuple_element<I,T> { using type = S; };
++
++void
++foo (T t, bool x)
++{
++  while (auto [ i, j ] = T { 1, 1, 3 })	// { dg-warning "structured bindings in conditions only available with" "" { target c++23_down } }
++    {
++      if (x)
++	break;
++    }
++}
++
++void
++bar (T t, bool x)
++{
++  for (int cnt = 0; auto [ i, j ] = T { 2, 2, 4 }; ++cnt)	// { dg-warning "structured bindings in conditions only available with" "" { target c++23_down } }
++    {
++      if (x)
++	break;
++    }
++}
+diff --git a/gcc/testsuite/g++.dg/expr/for9.C b/gcc/testsuite/g++.dg/expr/for9.C
+new file mode 100644
+index 000000000000..5f90a5c59f92
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/expr/for9.C
+@@ -0,0 +1,25 @@
++// PR c++/118822
++// { dg-do compile }
++
++struct A { A (); ~A (); };
++bool baz ();
++
++void
++foo ()
++{
++  while (bool x = baz ())
++    {
++    lab:;
++      A a;
++    }
++}
++
++void
++bar ()
++{
++  for (bool y = baz (); bool x = baz (); y |= x)
++    {
++    lab:;
++      A a;
++    }
++}
+
+base-commit: 3880271e94b7598b4f5d98c615b7fcddddee6d4c
+-- 
+2.48.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index be23e46..dc321b7 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 46	????
 
 	- 81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
+	+ 81_all_PR118822-c-Fix-up-regressions-caused-by-for-while-loops-with-.patch
 
 45	9 February 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-02-13  9:23 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-02-13  9:23 UTC (permalink / raw
  To: gentoo-commits
commit:     e6b63bba27639e7e5c6c3d7fc394639534f30aaf
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Feb 13 09:23:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Feb 13 09:23:27 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=e6b63bba
15.0.0: drop 81_all_PR118822-c-Fix-up-regressions-caused-by-for-while-loops-with-.patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...gressions-caused-by-for-while-loops-with-.patch | 562 ---------------------
 15.0.0/gentoo/README.history                       |   1 -
 2 files changed, 563 deletions(-)
diff --git a/15.0.0/gentoo/81_all_PR118822-c-Fix-up-regressions-caused-by-for-while-loops-with-.patch b/15.0.0/gentoo/81_all_PR118822-c-Fix-up-regressions-caused-by-for-while-loops-with-.patch
deleted file mode 100644
index cc1a3d6..0000000
--- a/15.0.0/gentoo/81_all_PR118822-c-Fix-up-regressions-caused-by-for-while-loops-with-.patch
+++ /dev/null
@@ -1,562 +0,0 @@
-From 94063edfaf24b3bd9ef392e2eefc6bc6f7fcfbab Mon Sep 17 00:00:00 2001
-Message-ID: <94063edfaf24b3bd9ef392e2eefc6bc6f7fcfbab.1739372825.git.sam@gentoo.org>
-From: Jakub Jelinek <jakub@redhat.com>
-Date: Tue, 11 Feb 2025 18:59:50 +0100
-Subject: [PATCH] c++: Fix up regressions caused by for/while loops with
- declarations [PR118822]
-
-Hi!
-
-The recent PR86769 r15-7426 changes regressed the following two testcases,
-the first one is more important as it is derived from real-world code.
-
-The first problem is that the chosen
-prep = do_pushlevel (sk_block);
-// emit something
-body = push_stmt_list ();
-// emit further stuff
-body = pop_stmt_list (body);
-prep = do_poplevel (prep);
-way of constructing the {FOR,WHILE}_COND_PREP and {FOR,WHILE}_BODY
-isn't reliable.  If during parsing a label is seen in the body and then
-some decl with destructors, sk_cleanup transparent scope is added, but
-the correspondiong result from push_stmt_list is saved in
-*current_binding_level and pop_stmt_list then pops even that statement list
-but only do_poplevel actually attempts to pop the sk_cleanup scope and so we
-ICE.
-The reason for not doing do_pushlevel (sk_block); do_pushlevel (sk_block);
-is that variables should be in the same scope (otherwise various e.g.
-redeclaration*.C tests FAIL) and doing do_pushlevel (sk_block); do_pushlevel
-(sk_cleanup); wouldn't work either as do_poplevel would silently unwind even
-the cleanup one.
-
-The second problem is that my assumption that the declaration in the
-condition will have zero or one cleanup is just wrong, at least for
-structured bindings used as condition, there can be as many cleanups as
-there are names in the binding + 1.
-
-So, the following patch changes the earlier approach.  Nothing is removed
-from the {FOR,WHILE}_COND_PREP subtrees while doing adjust_loop_decl_cond,
-push_stmt_list isn't called either; all it does is remember as an integer
-the number of cleanups (CLEANUP_STMT at the end of the STATEMENT_LISTs)
-from querying stmt_list_stack and finding the initial *body_p in there
-(that integer is stored into {FOR,WHILE}_COND_CLEANUP), and temporarily
-{FOR,WHILE}_BODY is set to the last statement (if any) in the innermost
-STATEMENT_LIST at the adjust_loop_decl_cond time; then at
-finish_{for,while}_stmt a new finish_loop_cond_prep routine takes care of
-do_poplevel for the scope (which is in {FOR,WHILE}_COND_PREP) and finds
-given {FOR,WHILE}_COND_CLEANUP number and {FOR,WHILE}_BODY tree the right
-spot where body statements start and moves that into {FOR,WHILE}_BODY.
-Finally genericize_c_loop then inserts the cond, body, continue label, expr
-into the right subtree of {FOR,WHILE}_COND_PREP.
-The constexpr evaluation unfortunately had to be changed as well, because
-we don't want to evaluate everything in BIND_EXPR_BODY (*_COND_PREP ())
-right away, we want to evaluate it with the exception of the CLEANUP_STMT
-cleanups at the end (given {FOR,WHILE}_COND_CLEANUP levels), and defer
-the evaluation of the cleanups until after cond, body, expr are evaluated.
-
-Bootstrapped/regtested on x86_64-linux and i686-linux, ok for trunk?
-
-2025-02-11  Jakub Jelinek  <jakub@redhat.com>
-
-	PR c++/118822
-	PR c++/118833
-gcc/c-family/
-	* c-common.h (WHILE_COND_CLEANUP): Change description in comment.
-	(FOR_COND_CLEANUP): Likewise.
-	* c-gimplify.cc (genericize_c_loop): Adjust for COND_CLEANUP
-	being CLEANUP_STMT/TRY_FINALLY_EXPR trailing nesting depth
-	instead of actual cleanup.
-gcc/cp/
-	* semantics.cc (adjust_loop_decl_cond): Allow multiple trailing
-	CLEANUP_STMT levels in *BODY_P.  Set *CLEANUP_P to the number
-	of levels rather than one particular cleanup, keep the cleanups
-	in *PREP_P.  Set *BODY_P to the last stmt in the cur_stmt_list
-	or NULL if *CLEANUP_P and the innermost cur_stmt_list is empty.
-	(finish_loop_cond_prep): New function.
-	(finish_while_stmt, finish_for_stmt): Use it.  Don't call
-	set_one_cleanup_loc.
-	* constexpr.cc (cxx_eval_loop_expr): Adjust handling of
-	{FOR,WHILE}_COND_{PREP,CLEANUP}.
-gcc/testsuite/
-	* g++.dg/expr/for9.C: New test.
-	* g++.dg/cpp26/decomp12.C: New test.
----
- gcc/c-family/c-common.h               |   6 +-
- gcc/c-family/c-gimplify.cc            |  41 +++-----
- gcc/cp/constexpr.cc                   |  83 ++++++++++++++--
- gcc/cp/semantics.cc                   | 135 +++++++++++++++++++-------
- gcc/testsuite/g++.dg/cpp26/decomp12.C |  46 +++++++++
- gcc/testsuite/g++.dg/expr/for9.C      |  25 +++++
- 6 files changed, 267 insertions(+), 69 deletions(-)
- create mode 100644 gcc/testsuite/g++.dg/cpp26/decomp12.C
- create mode 100644 gcc/testsuite/g++.dg/expr/for9.C
-
-diff --git a/gcc/c-family/c-common.h b/gcc/c-family/c-common.h
-index bc238430b7a7..ea6c29750567 100644
---- a/gcc/c-family/c-common.h
-+++ b/gcc/c-family/c-common.h
-@@ -1518,7 +1518,8 @@ extern tree build_userdef_literal (tree suffix_id, tree value,
- 
- /* WHILE_STMT accessors.  These give access to the condition of the
-    while statement, the body, and name of the while statement, and
--   condition preparation statements and its cleanup, respectively.  */
-+   condition preparation statements and number of its nested cleanups,
-+   respectively.  */
- #define WHILE_COND(NODE)	TREE_OPERAND (WHILE_STMT_CHECK (NODE), 0)
- #define WHILE_BODY(NODE)	TREE_OPERAND (WHILE_STMT_CHECK (NODE), 1)
- #define WHILE_NAME(NODE)	TREE_OPERAND (WHILE_STMT_CHECK (NODE), 2)
-@@ -1533,7 +1534,8 @@ extern tree build_userdef_literal (tree suffix_id, tree value,
- 
- /* FOR_STMT accessors.  These give access to the init statement,
-    condition, update expression, body and name of the for statement,
--   and condition preparation statements and its cleanup, respectively.  */
-+   and condition preparation statements and number of its nested cleanups,
-+   respectively.  */
- #define FOR_INIT_STMT(NODE)	TREE_OPERAND (FOR_STMT_CHECK (NODE), 0)
- #define FOR_COND(NODE)		TREE_OPERAND (FOR_STMT_CHECK (NODE), 1)
- #define FOR_EXPR(NODE)		TREE_OPERAND (FOR_STMT_CHECK (NODE), 2)
-diff --git a/gcc/c-family/c-gimplify.cc b/gcc/c-family/c-gimplify.cc
-index d53e0c2dc567..dc5e80dfa6be 100644
---- a/gcc/c-family/c-gimplify.cc
-+++ b/gcc/c-family/c-gimplify.cc
-@@ -258,8 +258,10 @@ expr_loc_or_loc (const_tree expr, location_t or_loc)
-    for C++ for/while loops with variable declaration as condition.  COND_PREP
-    is a BIND_EXPR with the declaration and initialization of the condition
-    variable, into which COND, BODY, continue label if needed and INCR if
--   non-NULL should be appended, and COND_CLEANUP are statements which should
--   be evaluated after that or if anything in COND, BODY or INCR throws.  */
-+   non-NULL should be appended, and COND_CLEANUP is number of nested
-+   CLEANUP_STMT -> TRY_FINALLY_EXPR statements at the end.  If non-NULL,
-+   COND, BODY, continue label if needed and INCR if non-NULL should be
-+   appended to the body of the COND_CLEANUP's nested TRY_FINALLY_EXPR.  */
- 
- static void
- genericize_c_loop (tree *stmt_p, location_t start_locus, tree cond, tree body,
-@@ -278,7 +280,6 @@ genericize_c_loop (tree *stmt_p, location_t start_locus, tree cond, tree body,
-   walk_tree_1 (&cond_prep, func, data, NULL, lh);
-   walk_tree_1 (&cond, func, data, NULL, lh);
-   walk_tree_1 (&incr, func, data, NULL, lh);
--  walk_tree_1 (&cond_cleanup, func, data, NULL, lh);
- 
-   blab = begin_bc_block (bc_break, start_locus);
-   clab = begin_bc_block (bc_continue, start_locus);
-@@ -309,36 +310,24 @@ genericize_c_loop (tree *stmt_p, location_t start_locus, tree cond, tree body,
- 	 EXPR;
- 	 goto top;
- 
--	 or
--
--	 try {
--	   if (COND); else break;
--	   BODY;
--	   cont:
--	   EXPR;
--	 } finally {
--	   COND_CLEANUP
--	 }
--
--	 appended into COND_PREP body.  */
-+	 appended into COND_PREP body or body of some TRY_FINALLY_EXPRs
-+	 at the end of COND_PREP.  */
-       gcc_assert (cond_is_first && TREE_CODE (cond_prep) == BIND_EXPR);
-       tree top = build1 (LABEL_EXPR, void_type_node,
- 			 create_artificial_label (start_locus));
-       exit = build1 (GOTO_EXPR, void_type_node, LABEL_EXPR_LABEL (top));
-       append_to_statement_list (top, &outer_stmt_list);
-       append_to_statement_list (cond_prep, &outer_stmt_list);
--      stmt_list = BIND_EXPR_BODY (cond_prep);
--      BIND_EXPR_BODY (cond_prep) = NULL_TREE;
-       stmt_list_p = &BIND_EXPR_BODY (cond_prep);
--      if (cond_cleanup && TREE_SIDE_EFFECTS (cond_cleanup))
--	{
--	  t = build2_loc (EXPR_LOCATION (cond_cleanup), TRY_FINALLY_EXPR,
--			  void_type_node, NULL_TREE, cond_cleanup);
--	  append_to_statement_list (t, &stmt_list);
--	  *stmt_list_p = stmt_list;
--	  stmt_list_p = &TREE_OPERAND (t, 0);
--	  stmt_list = NULL_TREE;
--	}
-+      if (cond_cleanup)
-+	for (unsigned depth = tree_to_uhwi (cond_cleanup); depth; --depth)
-+	  {
-+	    t = tsi_stmt (tsi_last (*stmt_list_p));
-+	    gcc_assert (TREE_CODE (t) == TRY_FINALLY_EXPR);
-+	    stmt_list_p = &TREE_OPERAND (t, 0);
-+	  }
-+      stmt_list = *stmt_list_p;
-+      *stmt_list_p = NULL_TREE;
-       tree after_cond = create_artificial_label (cond_locus);
-       tree goto_after_cond = build1 (GOTO_EXPR, void_type_node, after_cond);
-       t = build1 (GOTO_EXPR, void_type_node, get_bc_label (bc_break));
-diff --git a/gcc/cp/constexpr.cc b/gcc/cp/constexpr.cc
-index f142dd32bc80..bb012d9d8f0b 100644
---- a/gcc/cp/constexpr.cc
-+++ b/gcc/cp/constexpr.cc
-@@ -7153,6 +7153,7 @@ cxx_eval_loop_expr (const constexpr_ctx *ctx, tree t,
- 
-   tree body, cond = NULL_TREE, expr = NULL_TREE;
-   tree cond_prep = NULL_TREE, cond_cleanup = NULL_TREE;
-+  unsigned cond_cleanup_depth = 0;
-   int count = 0;
-   switch (TREE_CODE (t))
-     {
-@@ -7188,11 +7189,25 @@ cxx_eval_loop_expr (const constexpr_ctx *ctx, tree t,
-     }
-   if (cond_prep)
-     gcc_assert (TREE_CODE (cond_prep) == BIND_EXPR);
--  auto cleanup_cond = [=] {
-+  auto cleanup_cond = [=, &cond_cleanup_depth] {
-     /* Clean up the condition variable after each iteration.  */
--    if (cond_cleanup && !*non_constant_p)
--      cxx_eval_constant_expression (ctx, cond_cleanup, vc_discard,
--				    non_constant_p, overflow_p);
-+    if (cond_cleanup_depth && !*non_constant_p)
-+      {
-+	auto_vec<tree, 4> cleanups (cond_cleanup_depth);
-+	tree s = BIND_EXPR_BODY (cond_prep);
-+	unsigned i;
-+	for (i = cond_cleanup_depth; i; --i)
-+	  {
-+	    tree_stmt_iterator iter = tsi_last (s);
-+	    s = tsi_stmt (iter);
-+	    cleanups.quick_push (CLEANUP_EXPR (s));
-+	    s = CLEANUP_BODY (s);
-+	  }
-+	tree c;
-+	FOR_EACH_VEC_ELT_REVERSE (cleanups, i, c)
-+	  cxx_eval_constant_expression (ctx, c, vc_discard, non_constant_p,
-+					overflow_p);
-+      }
-     if (cond_prep)
-       for (tree decl = BIND_EXPR_VARS (cond_prep);
- 	   decl; decl = DECL_CHAIN (decl))
-@@ -7227,9 +7242,63 @@ cxx_eval_loop_expr (const constexpr_ctx *ctx, tree t,
- 	  for (tree decl = BIND_EXPR_VARS (cond_prep);
- 	       decl; decl = DECL_CHAIN (decl))
- 	    ctx->global->clear_value (decl);
--	  cxx_eval_constant_expression (ctx, BIND_EXPR_BODY (cond_prep),
--					vc_discard, non_constant_p,
--					overflow_p, jump_target);
-+	  if (cond_cleanup)
-+	    {
-+	      /* If COND_CLEANUP is non-NULL, we need to evaluate DEPTH
-+		 nested STATEMENT_EXPRs from inside of BIND_EXPR_BODY,
-+		 but defer the evaluation of CLEANUP_EXPRs at the end
-+		 of those STATEMENT_EXPRs.  */
-+	      cond_cleanup_depth = 0;
-+	      tree s = BIND_EXPR_BODY (cond_prep);
-+	      for (unsigned depth = tree_to_uhwi (cond_cleanup);
-+		   depth; --depth)
-+		{
-+		  for (tree_stmt_iterator i = tsi_start (s);
-+		       !tsi_end_p (i); ++i)
-+		    {
-+		      tree stmt = *i;
-+		      if (TREE_CODE (stmt) == DEBUG_BEGIN_STMT)
-+			continue;
-+		      if (tsi_one_before_end_p (i))
-+			{
-+			  gcc_assert (TREE_CODE (stmt) == CLEANUP_STMT);
-+			  if (*jump_target)
-+			    {
-+			      depth = 1;
-+			      break;
-+			    }
-+			  ++cond_cleanup_depth;
-+			  if (depth > 1)
-+			    {
-+			      s = CLEANUP_BODY (stmt);
-+			      break;
-+			    }
-+			  cxx_eval_constant_expression (ctx,
-+							CLEANUP_BODY (stmt),
-+							vc_discard,
-+							non_constant_p,
-+							overflow_p,
-+							jump_target);
-+			  break;
-+			}
-+		      cxx_eval_constant_expression (ctx, stmt, vc_discard,
-+						    non_constant_p, overflow_p,
-+						    jump_target);
-+		      if (*non_constant_p
-+			  || returns (jump_target)
-+			  || breaks (jump_target)
-+			  || continues (jump_target))
-+			{
-+			  depth = 1;
-+			  break;
-+			}
-+		    }
-+		}
-+	    }
-+	  else
-+	    cxx_eval_constant_expression (ctx, BIND_EXPR_BODY (cond_prep),
-+					  vc_discard, non_constant_p,
-+					  overflow_p, jump_target);
- 	}
- 
-       if (cond)
-diff --git a/gcc/cp/semantics.cc b/gcc/cp/semantics.cc
-index 8a2d86576fb0..2c3859e457ed 100644
---- a/gcc/cp/semantics.cc
-+++ b/gcc/cp/semantics.cc
-@@ -790,8 +790,8 @@ finish_cond (tree *cond_p, tree expr)
- 	    while (A x = 42) { }
- 	    for (; A x = 42;) { }
-    move the *BODY_P statements as a BIND_EXPR into {FOR,WHILE}_COND_PREP
--   and if there is any CLEANUP_STMT at the end, remove that and
--   put the cleanup into {FOR,WHILE}_COND_CLEANUP.
-+   and if there are any CLEANUP_STMT at the end, remember their count in
-+   {FOR,WHILE}_COND_CLEANUP.
-    genericize_c_loop will then handle it appropriately.  In particular,
-    the {FOR,WHILE}_COND, {FOR,WHILE}_BODY, if used continue label and
-    FOR_EXPR will be appended into the {FOR,WHILE}_COND_PREP BIND_EXPR,
-@@ -807,26 +807,95 @@ adjust_loop_decl_cond (tree *body_p, tree *prep_p, tree *cleanup_p)
-     return;
- 
-   gcc_assert (!processing_template_decl);
--  if (*body_p != cur_stmt_list)
--    {
--      /* There can be either no cleanup at all, if the condition
--	 declaration doesn't have non-trivial destructor, or a single
--	 one if it does.  In that case extract it into *CLEANUP_P.  */
--      gcc_assert (stmt_list_stack->length () > 1
--		  && (*stmt_list_stack)[stmt_list_stack->length ()
--					- 2] == *body_p);
--      tree_stmt_iterator last = tsi_last (*body_p);
--      gcc_assert (tsi_one_before_end_p (last)
--		  && TREE_CODE (tsi_stmt (last)) == CLEANUP_STMT
--		  && CLEANUP_BODY (tsi_stmt (last)) == cur_stmt_list
--		  && tsi_end_p (tsi_last (cur_stmt_list))
--		  && !CLEANUP_EH_ONLY (tsi_stmt (last)));
--      *cleanup_p = CLEANUP_EXPR (tsi_stmt (last));
--      tsi_delink (&last);
-+  *prep_p = *body_p;
-+  if (*prep_p != cur_stmt_list)
-+    {
-+      /* There can be just one CLEANUP_STMT, or there could be multiple
-+	 nested CLEANUP_STMTs, e.g. for structured bindings used as
-+	 condition.  */
-+      gcc_assert (stmt_list_stack->length () > 1);
-+      for (unsigned i = stmt_list_stack->length () - 2; ; --i)
-+	{
-+	  tree t = (*stmt_list_stack)[i];
-+	  tree_stmt_iterator last = tsi_last (t);
-+	  gcc_assert (tsi_one_before_end_p (last)
-+		      && TREE_CODE (tsi_stmt (last)) == CLEANUP_STMT
-+		      && (CLEANUP_BODY (tsi_stmt (last))
-+			  == (*stmt_list_stack)[i + 1])
-+		      && !CLEANUP_EH_ONLY (tsi_stmt (last)));
-+	  if (t == *prep_p)
-+	    {
-+	      *cleanup_p = build_int_cst (long_unsigned_type_node,
-+					  stmt_list_stack->length () - 1 - i);
-+	      break;
-+	    }
-+	  gcc_assert (i >= 1);
-+	}
-     }
-   current_binding_level->keep = true;
--  *prep_p = *body_p;
--  *body_p = push_stmt_list ();
-+  tree_stmt_iterator iter = tsi_last (cur_stmt_list);
-+  if (tsi_end_p (iter))
-+    *body_p = NULL_TREE;
-+  else
-+    *body_p = tsi_stmt (iter);
-+}
-+
-+/* Finalize {FOR,WHILE}_{BODY,COND_PREP} after the loop body.
-+   The above function initialized *BODY_P to the last statement
-+   in *PREP_P at that point.
-+   Call do_poplevel on *PREP_P and move everything after that
-+   former last statement into *BODY_P.  genericize_c_loop
-+   will later put those parts back together.
-+   CLEANUP is {FOR,WHILE}_COND_CLEANUP.  */
-+
-+static void
-+finish_loop_cond_prep (tree *body_p, tree *prep_p, tree cleanup)
-+{
-+  *prep_p = do_poplevel (*prep_p);
-+  gcc_assert (TREE_CODE (*prep_p) == BIND_EXPR);
-+  if (BIND_EXPR_BODY (*prep_p) == *body_p)
-+    {
-+      gcc_assert (cleanup == NULL_TREE);
-+      *body_p = build_empty_stmt (input_location);
-+      return;
-+    }
-+  gcc_assert (TREE_CODE (BIND_EXPR_BODY (*prep_p)) == STATEMENT_LIST);
-+  tree stmt_list = BIND_EXPR_BODY (*prep_p);
-+  if (cleanup)
-+    {
-+      tree_stmt_iterator iter = tsi_last (stmt_list);
-+      gcc_assert (TREE_CODE (tsi_stmt (iter)) == CLEANUP_STMT);
-+      for (unsigned depth = tree_to_uhwi (cleanup); depth > 1; --depth)
-+	{
-+	  gcc_assert (TREE_CODE (CLEANUP_BODY (tsi_stmt (iter)))
-+		      == STATEMENT_LIST);
-+	  iter = tsi_last (CLEANUP_BODY (tsi_stmt (iter)));
-+	  gcc_assert (TREE_CODE (tsi_stmt (iter)) == CLEANUP_STMT);
-+	}
-+      if (*body_p == NULL_TREE)
-+	{
-+	  *body_p = CLEANUP_BODY (tsi_stmt (iter));
-+	  CLEANUP_BODY (tsi_stmt (iter)) = build_empty_stmt (input_location);
-+	  return;
-+	}
-+      stmt_list = CLEANUP_BODY (tsi_stmt (iter));
-+    }
-+  tree_stmt_iterator iter = tsi_start (stmt_list);
-+  while (tsi_stmt (iter) != *body_p)
-+    tsi_next (&iter);
-+  if (tsi_one_before_end_p (iter))
-+    *body_p = build_empty_stmt (input_location);
-+  else
-+    {
-+      tsi_next (&iter);
-+      *body_p = NULL_TREE;
-+      while (!tsi_end_p (iter))
-+	{
-+	  tree t = tsi_stmt (iter);
-+	  tsi_delink (&iter);
-+	  append_to_statement_list_force (t, body_p);
-+	}
-+    }
- }
- 
- /* Finish a goto-statement.  */
-@@ -1437,14 +1506,13 @@ void
- finish_while_stmt (tree while_stmt)
- {
-   end_maybe_infinite_loop (boolean_true_node);
--  WHILE_BODY (while_stmt)
--    = (WHILE_COND_PREP (while_stmt)
--       ? pop_stmt_list (WHILE_BODY (while_stmt))
--       : do_poplevel (WHILE_BODY (while_stmt)));
--  finish_loop_cond (&WHILE_COND (while_stmt), WHILE_BODY (while_stmt));
-   if (WHILE_COND_PREP (while_stmt))
--    WHILE_COND_PREP (while_stmt) = do_poplevel (WHILE_COND_PREP (while_stmt));
--  set_one_cleanup_loc (WHILE_COND_CLEANUP (while_stmt), input_location);
-+    finish_loop_cond_prep (&WHILE_BODY (while_stmt),
-+			   &WHILE_COND_PREP (while_stmt),
-+			   WHILE_COND_CLEANUP (while_stmt));
-+  else
-+    WHILE_BODY (while_stmt) = do_poplevel (WHILE_BODY (while_stmt));
-+  finish_loop_cond (&WHILE_COND (while_stmt), WHILE_BODY (while_stmt));
- }
- 
- /* Begin a do-statement.  Returns a newly created DO_STMT if
-@@ -1709,17 +1777,16 @@ finish_for_stmt (tree for_stmt)
-     RANGE_FOR_BODY (for_stmt) = do_poplevel (RANGE_FOR_BODY (for_stmt));
-   else
-     {
--      FOR_BODY (for_stmt)
--	= (FOR_COND_PREP (for_stmt)
--	   ? pop_stmt_list (FOR_BODY (for_stmt))
--	   : do_poplevel (FOR_BODY (for_stmt)));
-+      if (FOR_COND_PREP (for_stmt))
-+	finish_loop_cond_prep (&FOR_BODY (for_stmt),
-+			       &FOR_COND_PREP (for_stmt),
-+			       FOR_COND_CLEANUP (for_stmt));
-+      else
-+	FOR_BODY (for_stmt) = do_poplevel (FOR_BODY (for_stmt));
-       if (FOR_COND (for_stmt))
- 	finish_loop_cond (&FOR_COND (for_stmt),
- 			  FOR_EXPR (for_stmt) ? integer_one_node
- 					      : FOR_BODY (for_stmt));
--      if (FOR_COND_PREP (for_stmt))
--	FOR_COND_PREP (for_stmt) = do_poplevel (FOR_COND_PREP (for_stmt));
--      set_one_cleanup_loc (FOR_COND_CLEANUP (for_stmt), input_location);
-     }
- 
-   /* Pop the scope for the body of the loop.  */
-diff --git a/gcc/testsuite/g++.dg/cpp26/decomp12.C b/gcc/testsuite/g++.dg/cpp26/decomp12.C
-new file mode 100644
-index 000000000000..c4f56aa5f6ad
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/cpp26/decomp12.C
-@@ -0,0 +1,46 @@
-+// P0963R3 - Structured binding declaration as a condition
-+// { dg-do compile { target c++11 } }
-+// { dg-options "" }
-+
-+namespace std {
-+  template<typename T> struct tuple_size;
-+  template<int, typename> struct tuple_element;
-+}
-+
-+struct S {
-+  S () : s (0) {}
-+  S (int x) : s (x) {}
-+  S (const S &x) : s (x.s) {}
-+  ~S () {}
-+  int s;
-+};
-+
-+struct T {
-+  S a, b, c;
-+  ~T () {}
-+  explicit operator bool () const noexcept { return a.s == b.s; }
-+  template <int I> S get () { return I ? a : b; }
-+};
-+
-+template<> struct std::tuple_size<T> { static const int value = 2; };
-+template<int I> struct std::tuple_element<I,T> { using type = S; };
-+
-+void
-+foo (T t, bool x)
-+{
-+  while (auto [ i, j ] = T { 1, 1, 3 })	// { dg-warning "structured bindings in conditions only available with" "" { target c++23_down } }
-+    {
-+      if (x)
-+	break;
-+    }
-+}
-+
-+void
-+bar (T t, bool x)
-+{
-+  for (int cnt = 0; auto [ i, j ] = T { 2, 2, 4 }; ++cnt)	// { dg-warning "structured bindings in conditions only available with" "" { target c++23_down } }
-+    {
-+      if (x)
-+	break;
-+    }
-+}
-diff --git a/gcc/testsuite/g++.dg/expr/for9.C b/gcc/testsuite/g++.dg/expr/for9.C
-new file mode 100644
-index 000000000000..5f90a5c59f92
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/expr/for9.C
-@@ -0,0 +1,25 @@
-+// PR c++/118822
-+// { dg-do compile }
-+
-+struct A { A (); ~A (); };
-+bool baz ();
-+
-+void
-+foo ()
-+{
-+  while (bool x = baz ())
-+    {
-+    lab:;
-+      A a;
-+    }
-+}
-+
-+void
-+bar ()
-+{
-+  for (bool y = baz (); bool x = baz (); y |= x)
-+    {
-+    lab:;
-+      A a;
-+    }
-+}
-
-base-commit: 3880271e94b7598b4f5d98c615b7fcddddee6d4c
--- 
-2.48.1
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index dc321b7..be23e46 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,7 +1,6 @@
 46	????
 
 	- 81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
-	+ 81_all_PR118822-c-Fix-up-regressions-caused-by-for-while-loops-with-.patch
 
 45	9 February 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-02-17  1:30 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-02-17  1:30 UTC (permalink / raw
  To: gentoo-commits
commit:     2f960908caaad18d54ce7cb764ac470656e664c4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Feb 17 01:29:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Feb 17 01:29:30 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=2f960908
15.0.0: cut patchset 46
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index be23e46..06c4a0d 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-46	????
+46	17 February 2025
 
 	- 81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-01  6:50 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-01  6:50 UTC (permalink / raw
  To: gentoo-commits
commit:     44cf2c670ce9e23133cd3d2a291fc465c739c25d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Mar  1 06:49:24 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Mar  1 06:49:24 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=44cf2c67
15.0.0: add JIT vs GGC fix (drop malloc attributes)
Add a workaround patch at https://gcc.gnu.org/bugzilla/show_bug.cgi?id=117047#c36.
It's really a correct fix but overkill, Jakub is proposing a more moderate
version that should land soon, but let's get this workaround in downstream first.
Bug: https://gcc.gnu.org/PR117047
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/81_all_PR117047-jit-gc-malloc.patch | 22 ++++++++++++++++++++++
 15.0.0/gentoo/README.history                      |  4 ++++
 2 files changed, 26 insertions(+)
diff --git a/15.0.0/gentoo/81_all_PR117047-jit-gc-malloc.patch b/15.0.0/gentoo/81_all_PR117047-jit-gc-malloc.patch
new file mode 100644
index 0000000..af8a23c
--- /dev/null
+++ b/15.0.0/gentoo/81_all_PR117047-jit-gc-malloc.patch
@@ -0,0 +1,22 @@
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=117047#c36
+--- a/gcc/ggc.h
++++ b/gcc/ggc.h
+@@ -127,8 +127,7 @@ extern void gt_pch_save (FILE *f);
+ 
+ /* The internal primitive.  */
+ extern void *ggc_internal_alloc (size_t, void (*)(void *), size_t,
+-				 size_t CXX_MEM_STAT_INFO)
+-     ATTRIBUTE_MALLOC;
++				 size_t CXX_MEM_STAT_INFO);
+ 
+ inline void *
+ ggc_internal_alloc (size_t s CXX_MEM_STAT_INFO)
+@@ -141,7 +140,7 @@ extern size_t ggc_round_alloc_size (size_t requested_size);
+ /* Allocates cleared memory.  */
+ extern void *ggc_internal_cleared_alloc (size_t, void (*)(void *),
+ 					 size_t, size_t
+-					 CXX_MEM_STAT_INFO) ATTRIBUTE_MALLOC;
++					 CXX_MEM_STAT_INFO);
+ 
+ inline void *
+ ggc_internal_cleared_alloc (size_t s CXX_MEM_STAT_INFO)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 06c4a0d..494be1f 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+47	????
+
+	+ 81_all_PR117047-jit-gc-malloc.patch
+
 46	17 February 2025
 
 	- 81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-01 10:33 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-01 10:33 UTC (permalink / raw
  To: gentoo-commits
commit:     e918ca6e86a909ffde50e9708ee9c98374b14472
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Mar  1 10:32:53 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Mar  1 10:32:53 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=e918ca6e
15.0.0: drop JIT patch
Jakub's is now upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/81_all_PR117047-jit-gc-malloc.patch | 22 ----------------------
 15.0.0/gentoo/README.history                      |  4 ----
 2 files changed, 26 deletions(-)
diff --git a/15.0.0/gentoo/81_all_PR117047-jit-gc-malloc.patch b/15.0.0/gentoo/81_all_PR117047-jit-gc-malloc.patch
deleted file mode 100644
index af8a23c..0000000
--- a/15.0.0/gentoo/81_all_PR117047-jit-gc-malloc.patch
+++ /dev/null
@@ -1,22 +0,0 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=117047#c36
---- a/gcc/ggc.h
-+++ b/gcc/ggc.h
-@@ -127,8 +127,7 @@ extern void gt_pch_save (FILE *f);
- 
- /* The internal primitive.  */
- extern void *ggc_internal_alloc (size_t, void (*)(void *), size_t,
--				 size_t CXX_MEM_STAT_INFO)
--     ATTRIBUTE_MALLOC;
-+				 size_t CXX_MEM_STAT_INFO);
- 
- inline void *
- ggc_internal_alloc (size_t s CXX_MEM_STAT_INFO)
-@@ -141,7 +140,7 @@ extern size_t ggc_round_alloc_size (size_t requested_size);
- /* Allocates cleared memory.  */
- extern void *ggc_internal_cleared_alloc (size_t, void (*)(void *),
- 					 size_t, size_t
--					 CXX_MEM_STAT_INFO) ATTRIBUTE_MALLOC;
-+					 CXX_MEM_STAT_INFO);
- 
- inline void *
- ggc_internal_cleared_alloc (size_t s CXX_MEM_STAT_INFO)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 494be1f..06c4a0d 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,7 +1,3 @@
-47	????
-
-	+ 81_all_PR117047-jit-gc-malloc.patch
-
 46	17 February 2025
 
 	- 81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-03 16:38 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-03 16:38 UTC (permalink / raw
  To: gentoo-commits
commit:     c8efdd40e70884f82c463ad5cf4c44c9e01125c3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Mar  3 16:37:51 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Mar  3 16:37:51 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=c8efdd40
15.0.0: add PGO patch for Firefox
Bug: https://gcc.gnu.org/PR118318
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../gentoo/81_all_PR118318-firefox-pgo-ice.patch   | 56 ++++++++++++++++++++++
 15.0.0/gentoo/README.history                       |  4 ++
 2 files changed, 60 insertions(+)
diff --git a/15.0.0/gentoo/81_all_PR118318-firefox-pgo-ice.patch b/15.0.0/gentoo/81_all_PR118318-firefox-pgo-ice.patch
new file mode 100644
index 0000000..4e01689
--- /dev/null
+++ b/15.0.0/gentoo/81_all_PR118318-firefox-pgo-ice.patch
@@ -0,0 +1,56 @@
+From 833d679c3c071b78dfb22015fe03d2cecfd650ec Mon Sep 17 00:00:00 2001
+Message-ID: <833d679c3c071b78dfb22015fe03d2cecfd650ec.1741019831.git.sam@gentoo.org>
+From: Martin Jambor <mjambor@suse.cz>
+Date: Mon, 3 Mar 2025 14:18:10 +0100
+Subject: [PATCH] ipa-cp: Avoid ICE when redistributing nodes among edges to
+ recursive clones (PR 118318)
+
+Hi,
+
+PR 118318 reported an ICE during PGO build of Firefox when IPA-CP, in
+the final stages of update_counts_for_self_gen_clones where it
+attempts to guess how to distribute profile count among clones created
+for recursive edges and the various edges that are created in the
+process.  If one such edge has profile count of kind GUESSED_GLOBAL0,
+the compatibility check in the operator+ will lead to an ICE.  After
+discussing the situation with Honza, we concluded that there is little
+more we can do other than check for this situation before touching the
+edge count, so this is what this patch does.
+
+Bootstrapped and LTO-profile-bootstrapped and tested on x86_64.  OK for
+master?  (Should I then backport this to active release branches?  I
+guess it would make sense.)
+
+Thanks,
+
+Martin
+
+gcc/ChangeLog:
+
+2025-02-28  Martin Jambor  <mjambor@suse.cz>
+
+PR ipa/118318
+	* ipa-cp.cc (adjust_clone_incoming_counts): Add a compatible_p check.
+---
+ gcc/ipa-cp.cc | 3 ++-
+ 1 file changed, 2 insertions(+), 1 deletion(-)
+
+diff --git a/gcc/ipa-cp.cc b/gcc/ipa-cp.cc
+index 3c994f24f540..264568989a96 100644
+--- a/gcc/ipa-cp.cc
++++ b/gcc/ipa-cp.cc
+@@ -4638,7 +4638,8 @@ adjust_clone_incoming_counts (cgraph_node *node,
+ 	cs->count = cs->count.combine_with_ipa_count (sum);
+       }
+     else if (!desc->processed_edges->contains (cs)
+-	     && cs->caller->clone_of == desc->orig)
++	     && cs->caller->clone_of == desc->orig
++	     && cs->count.compatible_p (desc->count))
+       {
+ 	cs->count += desc->count;
+ 	if (dump_file)
+
+base-commit: f1c30c6213fb228f1e8b5973d10c868b834a4acd
+-- 
+2.48.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 06c4a0d..abbecb3 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+47	????
+
+	+ 81_all_PR118318-firefox-pgo-ice.patch
+
 46	17 February 2025
 
 	- 81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-07 16:54 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-07 16:54 UTC (permalink / raw
  To: gentoo-commits
commit:     2b8999ef9c726c3a1b0c8d2e81a22dab550d4f00
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar  7 16:54:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar  7 16:54:27 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=2b8999ef
15.0.0: drop now-upstream PGO patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../gentoo/81_all_PR118318-firefox-pgo-ice.patch   | 56 ----------------------
 15.0.0/gentoo/README.history                       |  4 --
 2 files changed, 60 deletions(-)
diff --git a/15.0.0/gentoo/81_all_PR118318-firefox-pgo-ice.patch b/15.0.0/gentoo/81_all_PR118318-firefox-pgo-ice.patch
deleted file mode 100644
index 4e01689..0000000
--- a/15.0.0/gentoo/81_all_PR118318-firefox-pgo-ice.patch
+++ /dev/null
@@ -1,56 +0,0 @@
-From 833d679c3c071b78dfb22015fe03d2cecfd650ec Mon Sep 17 00:00:00 2001
-Message-ID: <833d679c3c071b78dfb22015fe03d2cecfd650ec.1741019831.git.sam@gentoo.org>
-From: Martin Jambor <mjambor@suse.cz>
-Date: Mon, 3 Mar 2025 14:18:10 +0100
-Subject: [PATCH] ipa-cp: Avoid ICE when redistributing nodes among edges to
- recursive clones (PR 118318)
-
-Hi,
-
-PR 118318 reported an ICE during PGO build of Firefox when IPA-CP, in
-the final stages of update_counts_for_self_gen_clones where it
-attempts to guess how to distribute profile count among clones created
-for recursive edges and the various edges that are created in the
-process.  If one such edge has profile count of kind GUESSED_GLOBAL0,
-the compatibility check in the operator+ will lead to an ICE.  After
-discussing the situation with Honza, we concluded that there is little
-more we can do other than check for this situation before touching the
-edge count, so this is what this patch does.
-
-Bootstrapped and LTO-profile-bootstrapped and tested on x86_64.  OK for
-master?  (Should I then backport this to active release branches?  I
-guess it would make sense.)
-
-Thanks,
-
-Martin
-
-gcc/ChangeLog:
-
-2025-02-28  Martin Jambor  <mjambor@suse.cz>
-
-PR ipa/118318
-	* ipa-cp.cc (adjust_clone_incoming_counts): Add a compatible_p check.
----
- gcc/ipa-cp.cc | 3 ++-
- 1 file changed, 2 insertions(+), 1 deletion(-)
-
-diff --git a/gcc/ipa-cp.cc b/gcc/ipa-cp.cc
-index 3c994f24f540..264568989a96 100644
---- a/gcc/ipa-cp.cc
-+++ b/gcc/ipa-cp.cc
-@@ -4638,7 +4638,8 @@ adjust_clone_incoming_counts (cgraph_node *node,
- 	cs->count = cs->count.combine_with_ipa_count (sum);
-       }
-     else if (!desc->processed_edges->contains (cs)
--	     && cs->caller->clone_of == desc->orig)
-+	     && cs->caller->clone_of == desc->orig
-+	     && cs->count.compatible_p (desc->count))
-       {
- 	cs->count += desc->count;
- 	if (dump_file)
-
-base-commit: f1c30c6213fb228f1e8b5973d10c868b834a4acd
--- 
-2.48.1
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index abbecb3..06c4a0d 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,7 +1,3 @@
-47	????
-
-	+ 81_all_PR118318-firefox-pgo-ice.patch
-
 46	17 February 2025
 
 	- 81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-11 10:32 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-11 10:32 UTC (permalink / raw
  To: gentoo-commits
commit:     9e712cac5576ed07beadba86b7f0d9e9dad76f8c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 11 10:31:12 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Mar 11 10:32:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=9e712cac
15.0.0: drop libatomic patch
It clashes with cobol which just got committed and the patch needs work
for RPATH anyway. I've pinged the author to ask if they plan on refining
it for 15 or retrying in 16.
Bug: https://bugs.gentoo.org/948103
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...358-Enable-automatic-linking-of-libatomic.patch | 3683 --------------------
 15.0.0/gentoo/README.history                       |    4 +
 2 files changed, 4 insertions(+), 3683 deletions(-)
diff --git a/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch b/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
deleted file mode 100644
index b911f3e..0000000
--- a/15.0.0/gentoo/80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
+++ /dev/null
@@ -1,3683 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/IA1PR12MB9031716BB477FC233DD9C60CCE1C2@IA1PR12MB9031.namprd12.prod.outlook.com/
-
-PR81358: Enable automatic linking of libatomic.
-
-ChangeLog:
-	PR driver/81358
-	* Makefile.def: Add dependencies for libatomic.
-	* Makefile.tpl: Export TARGET_CONFIGDIRS.
-	Add rules for no_atomic and dependency on libatomic for target
-	libraries.
-	* configure.ac: Add libatomic to bootstrap_target_libs.
-	* Makefile.in: Regenerate.
-	* configure: Regenerate.
-
-gcc/ChangeLog:
-	PR driver/81358
-	* common.opt: New option -flink-libatomic.
-	* gcc.cc (LINK_LIBATOMIC_SPEC): New macro.
-	* config/gnu-user.h (GNU_USER_TARGET_LINK_GCC_C_SEQUENCE_SPEC): Use
-	LINK_LIBATOMIC_SPEC.
-	* doc/invoke.texi: Document -flink-libatomic.
-	* configure.ac: Define TARGET_PROVIDES_LIBATOMIC.
-	* configure: Regenerate.
-	* config.in: Regenerate.
-	* common.opt.urls: Regenerate.
-
-libatomic/ChangeLog:
-	PR driver/81358
-	* Makefile.am: Pass -fno-link-libatomic.
-	New rule all.
-	* configure.ac: Assert that CFLAGS is set and pass -fno-link-libatomic. 
-	* Makefile.in: Regenerate.
-	* configure: Regenerate.
-
-Signed-off-by: Prathamesh Kulkarni <prathameshk@nvidia.com>
-Co-authored-by: Matthew Malcolmson <mmalcolmson@nvidia.com>
-
-diff --git a/Makefile.def b/Makefile.def
-index 19954e7d731..a765078ed41 100644
---- a/Makefile.def
-+++ b/Makefile.def
-@@ -648,13 +648,14 @@ dependencies = { module=all-m4; on=all-build-texinfo; };
- // on libgcc and newlib/libgloss.
- lang_env_dependencies = { module=libitm; cxx=true; };
- lang_env_dependencies = { module=libffi; cxx=true; };
--lang_env_dependencies = { module=newlib; no_c=true; };
--lang_env_dependencies = { module=libgloss; no_c=true; };
--lang_env_dependencies = { module=libgcc; no_gcc=true; no_c=true; };
-+lang_env_dependencies = { module=newlib; no_c=true; no_atomic=true; };
-+lang_env_dependencies = { module=libgloss; no_c=true; no_atomic=true; };
-+lang_env_dependencies = { module=libgcc; no_gcc=true; no_c=true; no_atomic=true; };
- // libiberty does not depend on newlib or libgloss because it must be
- // built newlib on some targets (e.g. Cygwin).  It still needs
- // a dependency on libgcc for native targets to configure.
--lang_env_dependencies = { module=libiberty; no_c=true; };
-+lang_env_dependencies = { module=libiberty; no_c=true; no_atomic=true; };
-+lang_env_dependencies = { module=libatomic; no_atomic=true; };
- 
- dependencies = { module=configure-target-fastjar; on=configure-target-zlib; };
- dependencies = { module=all-target-fastjar; on=all-target-zlib; };
-diff --git a/Makefile.in b/Makefile.in
-index 966d6045496..a7969d0614b 100644
---- a/Makefile.in
-+++ b/Makefile.in
-@@ -242,6 +242,7 @@ HOST_EXPORTS = \
- 	GMPINC="$(HOST_GMPINC)"; export GMPINC; \
- 	ISLLIBS="$(HOST_ISLLIBS)"; export ISLLIBS; \
- 	ISLINC="$(HOST_ISLINC)"; export ISLINC; \
-+	TARGET_CONFIGDIRS="$(TARGET_CONFIGDIRS)"; export TARGET_CONFIGDIRS; \
- 	XGCC_FLAGS_FOR_TARGET="$(XGCC_FLAGS_FOR_TARGET)"; export XGCC_FLAGS_FOR_TARGET; \
- @if gcc-bootstrap
- 	$(RPATH_ENVVAR)=`echo "$(TARGET_LIB_PATH)$$$(RPATH_ENVVAR)" | sed 's,::*,:,g;s,^:*,,;s,:*$$,,'`; export $(RPATH_ENVVAR); \
-@@ -68878,51 +68879,3240 @@ configure-target-libgrust: maybe-all-target-libgcc
- 
- configure-target-libstdc++-v3: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
-+configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
-+configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
-+configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-rda: maybe-all-stage1-target-libatomic
-+configure-stage2-target-rda: maybe-all-stage2-target-libatomic
-+configure-stage3-target-rda: maybe-all-stage3-target-libatomic
-+configure-stage4-target-rda: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libada: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libada: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libada: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libada: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libsanitizer: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
-+configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
-+configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
-+configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-rda: maybe-all-stage1-target-libatomic
-+configure-stage2-target-rda: maybe-all-stage2-target-libatomic
-+configure-stage3-target-rda: maybe-all-stage3-target-libatomic
-+configure-stage4-target-rda: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libada: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libada: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libada: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libada: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libvtv: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
-+configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
-+configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
-+configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-rda: maybe-all-stage1-target-libatomic
-+configure-stage2-target-rda: maybe-all-stage2-target-libatomic
-+configure-stage3-target-rda: maybe-all-stage3-target-libatomic
-+configure-stage4-target-rda: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libada: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libada: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libada: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libada: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libssp: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
-+
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
- 
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
-+
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
-+configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
-+configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
-+configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-rda: maybe-all-stage1-target-libatomic
-+configure-stage2-target-rda: maybe-all-stage2-target-libatomic
-+configure-stage3-target-rda: maybe-all-stage3-target-libatomic
-+configure-stage4-target-rda: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libada: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libada: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libada: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libada: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
- 
- configure-target-libbacktrace: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
-+configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
-+configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
-+configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-rda: maybe-all-stage1-target-libatomic
-+configure-stage2-target-rda: maybe-all-stage2-target-libatomic
-+configure-stage3-target-rda: maybe-all-stage3-target-libatomic
-+configure-stage4-target-rda: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libada: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libada: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libada: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libada: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libquadmath: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libgfortran: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libobjc: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libgo: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libphobos: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
-+configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
-+configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
-+configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-rda: maybe-all-stage1-target-libatomic
-+configure-stage2-target-rda: maybe-all-stage2-target-libatomic
-+configure-stage3-target-rda: maybe-all-stage3-target-libatomic
-+configure-stage4-target-rda: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libada: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libada: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libada: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libada: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libtermcap: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-winsup: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
-+
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
- 
- configure-target-libffi: maybe-all-target-newlib maybe-all-target-libgloss
- configure-target-libffi: maybe-all-target-libstdc++-v3
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-zlib: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
-+configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
-+configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
-+configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-rda: maybe-all-stage1-target-libatomic
-+configure-stage2-target-rda: maybe-all-stage2-target-libatomic
-+configure-stage3-target-rda: maybe-all-stage3-target-libatomic
-+configure-stage4-target-rda: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libada: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libada: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libada: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libada: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-rda: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libada: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libgm2: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libgomp: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
-+configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
-+configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
-+configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-rda: maybe-all-stage1-target-libatomic
-+configure-stage2-target-rda: maybe-all-stage2-target-libatomic
-+configure-stage3-target-rda: maybe-all-stage3-target-libatomic
-+configure-stage4-target-rda: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libada: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libada: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libada: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libada: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libitm: maybe-all-target-newlib maybe-all-target-libgloss
- configure-target-libitm: maybe-all-target-libstdc++-v3
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libatomic: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libssp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libssp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libssp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libssp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libssp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libssp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libssp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libssp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libssp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libquadmath: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libquadmath: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libquadmath: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libquadmath: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libquadmath: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libquadmath: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libquadmath: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libquadmath: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libquadmath: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgfortran: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgfortran: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgfortran: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgfortran: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgfortran: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgfortran: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgfortran: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgfortran: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgfortran: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libobjc: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libobjc: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libobjc: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libobjc: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libobjc: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libobjc: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libobjc: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libobjc: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libobjc: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgo: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgo: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgo: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgo: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgo: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgo: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgo: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgo: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgo: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libtermcap: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libtermcap: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libtermcap: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libtermcap: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libtermcap: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libtermcap: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libtermcap: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libtermcap: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libtermcap: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-winsup: maybe-all-stage1-target-libatomic
-+configure-stage2-target-winsup: maybe-all-stage2-target-libatomic
-+configure-stage3-target-winsup: maybe-all-stage3-target-libatomic
-+configure-stage4-target-winsup: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-winsup: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-winsup: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-winsup: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-winsup: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-winsup: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libffi: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libffi: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libffi: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libffi: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libffi: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libffi: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libffi: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libffi: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libffi: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-rda: maybe-all-stage1-target-libatomic
-+configure-stage2-target-rda: maybe-all-stage2-target-libatomic
-+configure-stage3-target-rda: maybe-all-stage3-target-libatomic
-+configure-stage4-target-rda: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-rda: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-rda: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-rda: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-rda: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-rda: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libada: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libada: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libada: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libada: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libada: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libada: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libada: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libada: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libada: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgm2: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgm2: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgm2: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgm2: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgm2: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgm2: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgm2: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgm2: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgm2: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libitm: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libitm: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libitm: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libitm: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libitm: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libitm: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libitm: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libitm: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libitm: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgrust: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgrust: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgrust: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgrust: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgrust: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgrust: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgrust: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgrust: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgrust: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- configure-target-libgrust: maybe-all-target-newlib maybe-all-target-libgloss
- 
-+@if gcc-bootstrap
-+configure-stage1-target-libstdc++-v3: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libstdc++-v3: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libstdc++-v3: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libstdc++-v3: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libstdc++-v3: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libstdc++-v3: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libstdc++-v3: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libstdc++-v3: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libstdc++-v3: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libsanitizer: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libsanitizer: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libsanitizer: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libsanitizer: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libsanitizer: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libsanitizer: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libsanitizer: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libsanitizer: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libsanitizer: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libvtv: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libvtv: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libvtv: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libvtv: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libvtv: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libvtv: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libvtv: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libvtv: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libvtv: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libbacktrace: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libbacktrace: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libbacktrace: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libbacktrace: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libbacktrace: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libbacktrace: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libbacktrace: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libbacktrace: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libbacktrace: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libphobos: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libphobos: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libphobos: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libphobos: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libphobos: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libphobos: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libphobos: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libphobos: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libphobos: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-zlib: maybe-all-stage1-target-libatomic
-+configure-stage2-target-zlib: maybe-all-stage2-target-libatomic
-+configure-stage3-target-zlib: maybe-all-stage3-target-libatomic
-+configure-stage4-target-zlib: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-zlib: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-zlib: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-zlib: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-zlib: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-zlib: maybe-all-stageautofeedback-target-libatomic
-+configure-stage1-target-libgomp: maybe-all-stage1-target-libatomic
-+configure-stage2-target-libgomp: maybe-all-stage2-target-libatomic
-+configure-stage3-target-libgomp: maybe-all-stage3-target-libatomic
-+configure-stage4-target-libgomp: maybe-all-stage4-target-libatomic
-+configure-stageprofile-target-libgomp: maybe-all-stageprofile-target-libatomic
-+configure-stagetrain-target-libgomp: maybe-all-stagetrain-target-libatomic
-+configure-stagefeedback-target-libgomp: maybe-all-stagefeedback-target-libatomic
-+configure-stageautoprofile-target-libgomp: maybe-all-stageautoprofile-target-libatomic
-+configure-stageautofeedback-target-libgomp: maybe-all-stageautofeedback-target-libatomic
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap
-+configure-target-libstdc++-v3: maybe-all-target-libatomic
-+configure-target-libsanitizer: maybe-all-target-libatomic
-+configure-target-libvtv: maybe-all-target-libatomic
-+configure-target-libssp: maybe-all-target-libatomic
-+configure-target-libbacktrace: maybe-all-target-libatomic
-+configure-target-libquadmath: maybe-all-target-libatomic
-+configure-target-libgfortran: maybe-all-target-libatomic
-+configure-target-libobjc: maybe-all-target-libatomic
-+configure-target-libgo: maybe-all-target-libatomic
-+configure-target-libphobos: maybe-all-target-libatomic
-+configure-target-libtermcap: maybe-all-target-libatomic
-+configure-target-winsup: maybe-all-target-libatomic
-+configure-target-libffi: maybe-all-target-libatomic
-+configure-target-zlib: maybe-all-target-libatomic
-+configure-target-rda: maybe-all-target-libatomic
-+configure-target-libada: maybe-all-target-libatomic
-+configure-target-libgm2: maybe-all-target-libatomic
-+configure-target-libgomp: maybe-all-target-libatomic
-+configure-target-libitm: maybe-all-target-libatomic
-+configure-target-libgrust: maybe-all-target-libatomic
-+@endif gcc-no-bootstrap
-+
- 
- CONFIGURE_GDB_TK = @CONFIGURE_GDB_TK@
- GDB_TK = @GDB_TK@
-diff --git a/Makefile.tpl b/Makefile.tpl
-index da38dca697a..7edcfafb8e5 100644
---- a/Makefile.tpl
-+++ b/Makefile.tpl
-@@ -245,6 +245,7 @@ HOST_EXPORTS = \
- 	GMPINC="$(HOST_GMPINC)"; export GMPINC; \
- 	ISLLIBS="$(HOST_ISLLIBS)"; export ISLLIBS; \
- 	ISLINC="$(HOST_ISLINC)"; export ISLINC; \
-+	TARGET_CONFIGDIRS="$(TARGET_CONFIGDIRS)"; export TARGET_CONFIGDIRS; \
- 	XGCC_FLAGS_FOR_TARGET="$(XGCC_FLAGS_FOR_TARGET)"; export XGCC_FLAGS_FOR_TARGET; \
- @if gcc-bootstrap
- 	$(RPATH_ENVVAR)=`echo "$(TARGET_LIB_PATH)$$$(RPATH_ENVVAR)" | sed 's,::*,:,g;s,^:*,,;s,:*$$,,'`; export $(RPATH_ENVVAR); \
-@@ -2096,6 +2097,11 @@ ENDFOR dependencies +]@endif gcc-bootstrap
-    (if (exist? "no_gcc")
-        (hash-create-handle! lang-env-deps
- 	  (string-append (get "module") "-" "no_gcc") #t))
-+
-+   (if (exist? "no_atomic")
-+       (hash-create-handle! lang-env-deps
-+	  (string-append (get "module") "-" "no_atomic") #t))
-+
-    "" +][+ ENDFOR lang_env_dependencies +]
- 
- @if gcc-bootstrap[+ FOR target_modules +][+ IF (not (lang-dep "no_gcc"))
-@@ -2114,6 +2120,17 @@ configure-target-[+module+]: maybe-all-target-newlib maybe-all-target-libgloss[+
-   ENDIF +][+ IF (lang-dep "cxx") +]
- configure-target-[+module+]: maybe-all-target-libstdc++-v3[+
-   ENDIF +]
-+
-+@if gcc-bootstrap[+ FOR target_modules +][+ IF (not (lang-dep "no_atomic"))
-+  +][+ IF bootstrap +][+ FOR bootstrap_stage +]
-+configure-stage[+id+]-target-[+module+]: maybe-all-stage[+id+]-target-libatomic[+
-+  ENDFOR +][+ ENDIF bootstrap +][+ ENDIF +][+ ENDFOR target_modules +]
-+@endif gcc-bootstrap
-+
-+@if gcc-no-bootstrap[+ FOR target_modules +][+ IF (not (lang-dep "no_atomic")) +]
-+configure-target-[+module+]: maybe-all-target-libatomic[+
-+  ENDIF +][+ ENDFOR target_modules +]
-+@endif gcc-no-bootstrap
- [+ ENDFOR target_modules +]
- 
- CONFIGURE_GDB_TK = @CONFIGURE_GDB_TK@
-diff --git a/configure b/configure
-index 4ae8e1242af..532e4527719 100755
---- a/configure
-+++ b/configure
-@@ -10924,6 +10924,11 @@ if echo " ${target_configdirs} " | grep " libgomp " > /dev/null 2>&1 ; then
-   bootstrap_target_libs=${bootstrap_target_libs}target-libgomp,
- fi
- 
-+# If we are building libatomic, bootstrap it.
-+if echo " ${target_configdirs} " | grep " libatomic " > /dev/null 2>&1 ; then
-+  bootstrap_target_libs=${bootstrap_target_libs}target-libatomic,
-+fi
-+
- # If we are building libsanitizer and $BUILD_CONFIG contains bootstrap-asan
- # or bootstrap-ubsan, bootstrap it.
- if echo " ${target_configdirs} " | grep " libsanitizer " > /dev/null 2>&1; then
-diff --git a/configure.ac b/configure.ac
-index 9a72b2311bd..c44d84f32ce 100644
---- a/configure.ac
-+++ b/configure.ac
-@@ -3151,6 +3151,11 @@ if echo " ${target_configdirs} " | grep " libgomp " > /dev/null 2>&1 ; then
-   bootstrap_target_libs=${bootstrap_target_libs}target-libgomp,
- fi
- 
-+# If we are building libatomic, bootstrap it.
-+if echo " ${target_configdirs} " | grep " libatomic " > /dev/null 2>&1 ; then
-+  bootstrap_target_libs=${bootstrap_target_libs}target-libatomic,
-+fi
-+
- # If we are building libsanitizer and $BUILD_CONFIG contains bootstrap-asan
- # or bootstrap-ubsan, bootstrap it.
- if echo " ${target_configdirs} " | grep " libsanitizer " > /dev/null 2>&1; then
-diff --git a/gcc/common.opt b/gcc/common.opt
-index e2ac99df1d0..cbb6a791c89 100644
---- a/gcc/common.opt
-+++ b/gcc/common.opt
-@@ -3361,6 +3361,9 @@ Use the Modern linker (MOLD) linker instead of the default linker.
- fuse-linker-plugin
- Common Undocumented Var(flag_use_linker_plugin)
- 
-+flink-libatomic
-+Common Driver Var(flag_link_libatomic) Init(1)
-+
- ; Positive if we should track variables, negative if we should run
- ; the var-tracking pass only to discard debug annotations, zero if
- ; we're not to run it.
-diff --git a/gcc/common.opt.urls b/gcc/common.opt.urls
-index 79c322bed2b..0f076332abc 100644
---- a/gcc/common.opt.urls
-+++ b/gcc/common.opt.urls
-@@ -1573,6 +1573,9 @@ UrlSuffix(gcc/Link-Options.html#index-fuse-ld_003dmold)
- fuse-linker-plugin
- UrlSuffix(gcc/Optimize-Options.html#index-fuse-linker-plugin)
- 
-+flink-libatomic
-+UrlSuffix(gcc/C-Dialect-Options.html#index-flink-libatomic)
-+
- fvar-tracking
- UrlSuffix(gcc/Debugging-Options.html#index-fvar-tracking)
- 
-diff --git a/gcc/config.in b/gcc/config.in
-index 44de5a54611..621ca6f2b88 100644
---- a/gcc/config.in
-+++ b/gcc/config.in
-@@ -2565,6 +2565,12 @@
- #endif
- 
- 
-+/* Define if libatomic is built for the target. */
-+#ifndef USED_FOR_TARGET
-+#undef TARGET_PROVIDES_LIBATOMIC
-+#endif
-+
-+
- /* Define to 1 if you can safely include both <sys/time.h> and <time.h>. */
- #ifndef USED_FOR_TARGET
- #undef TIME_WITH_SYS_TIME
-diff --git a/gcc/config/gnu-user.h b/gcc/config/gnu-user.h
-index 4c4e31efa39..151871540e7 100644
---- a/gcc/config/gnu-user.h
-+++ b/gcc/config/gnu-user.h
-@@ -109,8 +109,9 @@ see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
- #define LINK_EH_SPEC "%{!static|static-pie:--eh-frame-hdr} "
- #endif
- 
-+
- #define GNU_USER_TARGET_LINK_GCC_C_SEQUENCE_SPEC \
--  "%{static|static-pie:--start-group} %G %{!nolibc:%L} \
-+  "%{static|static-pie:--start-group} %G %{!nolibc:" LINK_LIBATOMIC_SPEC "%L} \
-    %{static|static-pie:--end-group}%{!static:%{!static-pie:%G}}"
- 
- #undef LINK_GCC_C_SEQUENCE_SPEC
-diff --git a/gcc/configure b/gcc/configure
-index a495762724d..d94f10c9ff1 100755
---- a/gcc/configure
-+++ b/gcc/configure
-@@ -33420,6 +33420,12 @@ $as_echo "#define ENABLE_DEFAULT_SSP 1" >>confdefs.h
- fi
- 
- 
-+if echo " ${TARGET_CONFIGDIRS} " | grep " libatomic " > /dev/null 2>&1 ; then
-+
-+$as_echo "#define TARGET_PROVIDES_LIBATOMIC 1" >>confdefs.h
-+
-+fi
-+
- # Test for <sys/sdt.h> on the target.
- 
- { $as_echo "$as_me:${as_lineno-$LINENO}: checking sys/sdt.h in the target C library" >&5
-diff --git a/gcc/configure.ac b/gcc/configure.ac
-index 24261638096..537b8f79936 100644
---- a/gcc/configure.ac
-+++ b/gcc/configure.ac
-@@ -7011,6 +7011,11 @@ if test x$enable_default_ssp = xyes ; then
- fi
- AC_SUBST([enable_default_ssp])
- 
-+if echo " ${TARGET_CONFIGDIRS} " | grep " libatomic " > /dev/null 2>&1 ; then
-+  AC_DEFINE(TARGET_PROVIDES_LIBATOMIC, 1,
-+	    [Define if libatomic is built for the target.])
-+fi
-+
- # Test for <sys/sdt.h> on the target.
- GCC_TARGET_TEMPLATE([HAVE_SYS_SDT_H])
- AC_CACHE_CHECK([sys/sdt.h in the target C library], [gcc_cv_sys_sdt_h], [
-diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
-index 0a7a81b2067..bb6b003dd7f 100644
---- a/gcc/doc/invoke.texi
-+++ b/gcc/doc/invoke.texi
-@@ -206,7 +206,7 @@ in the following sections.
- -fpermitted-flt-eval-methods=@var{standard}
- -fplan9-extensions  -fsigned-bitfields  -funsigned-bitfields
- -fsigned-char  -funsigned-char  -fstrict-flex-arrays[=@var{n}]
---fsso-struct=@var{endianness}}
-+-fsso-struct=@var{endianness} -flink-libatomic}
- 
- @item C++ Language Options
- @xref{C++ Dialect Options,,Options Controlling C++ Dialect}.
-@@ -2900,6 +2900,13 @@ The @option{-fstrict_flex_arrays} option interacts with the
- @option{-Wstrict-flex-arrays} option.  @xref{Warning Options}, for more
- information.
- 
-+@opindex flink-libatomic
-+@item -flink-libatomic
-+Enable linking of libatomic if it's supported by target.  Enabled by default,
-+and currently supported on targets using glibc. The negative form
-+@option{-fno-link-libatomic} can be used to explicitly disable linking of
-+libatomic.
-+
- @opindex fsso-struct
- @item -fsso-struct=@var{endianness}
- Set the default scalar storage order of structures and unions to the
-diff --git a/gcc/gcc.cc b/gcc/gcc.cc
-index 95b98eaa83c..d7877d56b46 100644
---- a/gcc/gcc.cc
-+++ b/gcc/gcc.cc
-@@ -980,6 +980,13 @@ proper position among the other output files.  */
- 
- /* Here is the spec for running the linker, after compiling all files.  */
- 
-+#if defined(TARGET_PROVIDES_LIBATOMIC) && defined(USE_LD_AS_NEEDED)
-+#define LINK_LIBATOMIC_SPEC "%{!fno-link-libatomic:" LD_AS_NEEDED_OPTION \
-+			    " -latomic " LD_NO_AS_NEEDED_OPTION "} "
-+#else
-+#define LINK_LIBATOMIC_SPEC ""
-+#endif
-+
- /* This is overridable by the target in case they need to specify the
-    -lgcc and -lc order specially, yet not require them to override all
-    of LINK_COMMAND_SPEC.  */
-diff --git a/libatomic/Makefile.am b/libatomic/Makefile.am
-index 0f1a7156084..5938f33ae7f 100644
---- a/libatomic/Makefile.am
-+++ b/libatomic/Makefile.am
-@@ -69,7 +69,7 @@ libatomic_darwin_rpath += -Wl,-rpath,@loader_path
- endif
- 
- libatomic_la_LDFLAGS = $(libatomic_version_info) $(libatomic_version_script) \
--	$(lt_host_flags) $(libatomic_darwin_rpath)
-+	-Wc,-fno-link-libatomic $(lt_host_flags) $(libatomic_darwin_rpath)
- libatomic_la_SOURCES = gload.c gstore.c gcas.c gexch.c glfree.c lock.c init.c \
- 	fenv.c fence.c flag.c
- 
-@@ -162,6 +162,10 @@ libatomic_convenience_la_LIBADD = $(libatomic_la_LIBADD)
- # when it is reloaded during the build of all-multi.
- all-multi: $(libatomic_la_LIBADD)
- 
-+gcc_objdir = `pwd`/$(MULTIBUILDTOP)../../gcc/
-+all: all-multi libatomic.la libatomic_convenience.la
-+	$(LIBTOOL) --mode=install $(INSTALL_DATA) libatomic.la $(gcc_objdir)$(MULTISUBDIR)/
-+
- # target overrides
- -include $(tmake_file)
- 
-diff --git a/libatomic/Makefile.in b/libatomic/Makefile.in
-index 9798e7c09e9..fb2d447707e 100644
---- a/libatomic/Makefile.in
-+++ b/libatomic/Makefile.in
-@@ -421,7 +421,7 @@ libatomic_version_info = -version-info $(libtool_VERSION)
- @ENABLE_DARWIN_AT_RPATH_TRUE@	-Wc,-nodefaultrpaths \
- @ENABLE_DARWIN_AT_RPATH_TRUE@	-Wl,-rpath,@loader_path
- libatomic_la_LDFLAGS = $(libatomic_version_info) $(libatomic_version_script) \
--	$(lt_host_flags) $(libatomic_darwin_rpath)
-+	-Wc,-fno-link-libatomic $(lt_host_flags) $(libatomic_darwin_rpath)
- 
- libatomic_la_SOURCES = gload.c gstore.c gcas.c gexch.c glfree.c lock.c \
- 	init.c fenv.c fence.c flag.c $(am__append_5)
-@@ -458,6 +458,7 @@ libatomic_la_LIBADD = $(foreach s,$(SIZES),$(addsuffix \
- @ARCH_X86_64_TRUE@@HAVE_IFUNC_TRUE@IFUNC_OPTIONS = -mcx16 -mcx16
- libatomic_convenience_la_SOURCES = $(libatomic_la_SOURCES)
- libatomic_convenience_la_LIBADD = $(libatomic_la_LIBADD)
-+gcc_objdir = `pwd`/$(MULTIBUILDTOP)../../gcc/
- MULTISRCTOP = 
- MULTIBUILDTOP = 
- MULTIDIRS = 
-@@ -901,6 +902,8 @@ vpath % $(strip $(search_path))
- # makefile fragments to avoid broken *.Ppo getting included into the Makefile
- # when it is reloaded during the build of all-multi.
- all-multi: $(libatomic_la_LIBADD)
-+all: all-multi libatomic.la libatomic_convenience.la
-+	$(LIBTOOL) --mode=install $(INSTALL_DATA) libatomic.la $(gcc_objdir)$(MULTISUBDIR)/
- 
- # target overrides
- -include $(tmake_file)
-diff --git a/libatomic/configure b/libatomic/configure
-index d579bab96f8..90a5a3b479a 100755
---- a/libatomic/configure
-+++ b/libatomic/configure
-@@ -3415,6 +3415,26 @@ esac
- # the wrong, non-multilib-adjusted value will be used in multilibs.
- # As a side effect, we have to subst CFLAGS ourselves.
- 
-+# AC_PROG_CC sets CFLAGS to "-g -O2" by default (if unset), and
-+# then compile conftests with default CFLAGS, leaving no place to temporarily
-+# modify CFLAGS and restore them later.  However we need to pass
-+# -fno-link-libatomic in CFLAGS so conftests compiled in AC_PROG_CC don't fail.
-+# Assert that CFLAGS is always set by user so the default setting of CFLAGS by
-+# AC_PROG_CC won't be applicable anyway.
-+if test -z "${CFLAGS}"; then
-+  as_fn_error $? "CFLAGS must be set." "$LINENO" 5
-+fi
-+
-+# In order to override CFLAGS_FOR_TARGET, all of our special flags go
-+# in XCFLAGS.  But we need them in CFLAGS during configury.  So put them
-+# in both places for now and restore CFLAGS at the end of config.
-+save_CFLAGS="$CFLAGS"
-+
-+# Append -fno-link-libatomic to avoid automatically linking libatomic,
-+# while building libatomic itself.
-+XCFLAGS="$XCFLAGS -fno-link-libatomic"
-+CFLAGS="$save_CFLAGS $XCFLAGS"
-+
- 
- 
- ac_ext=c
-@@ -4593,11 +4613,6 @@ fi
- 
- 
- 
--# In order to override CFLAGS_FOR_TARGET, all of our special flags go
--# in XCFLAGS.  But we need them in CFLAGS during configury.  So put them
--# in both places for now and restore CFLAGS at the end of config.
--save_CFLAGS="$CFLAGS"
--
- # Find other programs we need.
- if test -n "$ac_tool_prefix"; then
-   # Extract the first word of "${ac_tool_prefix}ar", so it can be a program name with args.
-@@ -11456,7 +11471,7 @@ else
-   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
-   lt_status=$lt_dlunknown
-   cat > conftest.$ac_ext <<_LT_EOF
--#line 11459 "configure"
-+#line 11474 "configure"
- #include "confdefs.h"
- 
- #if HAVE_DLFCN_H
-@@ -11562,7 +11577,7 @@ else
-   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
-   lt_status=$lt_dlunknown
-   cat > conftest.$ac_ext <<_LT_EOF
--#line 11565 "configure"
-+#line 11580 "configure"
- #include "confdefs.h"
- 
- #if HAVE_DLFCN_H
-diff --git a/libatomic/configure.ac b/libatomic/configure.ac
-index aafae71028d..298b04097a9 100644
---- a/libatomic/configure.ac
-+++ b/libatomic/configure.ac
-@@ -129,6 +129,26 @@ AC_SUBST(toolexeclibdir)
- # the wrong, non-multilib-adjusted value will be used in multilibs.
- # As a side effect, we have to subst CFLAGS ourselves.
- 
-+# AC_PROG_CC sets CFLAGS to "-g -O2" by default (if unset), and
-+# then compile conftests with default CFLAGS, leaving no place to temporarily
-+# modify CFLAGS and restore them later.  However we need to pass
-+# -fno-link-libatomic in CFLAGS so conftests compiled in AC_PROG_CC don't fail.
-+# Assert that CFLAGS is always set by user so the default setting of CFLAGS by
-+# AC_PROG_CC won't be applicable anyway.
-+if test -z "${CFLAGS}"; then
-+  AC_MSG_ERROR([CFLAGS must be set.])
-+fi
-+
-+# In order to override CFLAGS_FOR_TARGET, all of our special flags go
-+# in XCFLAGS.  But we need them in CFLAGS during configury.  So put them
-+# in both places for now and restore CFLAGS at the end of config.
-+save_CFLAGS="$CFLAGS"
-+
-+# Append -fno-link-libatomic to avoid automatically linking libatomic,
-+# while building libatomic itself.
-+XCFLAGS="$XCFLAGS -fno-link-libatomic"
-+CFLAGS="$save_CFLAGS $XCFLAGS"
-+
- m4_rename([_AC_ARG_VAR_PRECIOUS],[real_PRECIOUS])
- m4_define([_AC_ARG_VAR_PRECIOUS],[])
- AC_PROG_CC
-@@ -137,11 +157,6 @@ m4_rename_force([real_PRECIOUS],[_AC_ARG_VAR_PRECIOUS])
- 
- AC_SUBST(CFLAGS)
- 
--# In order to override CFLAGS_FOR_TARGET, all of our special flags go
--# in XCFLAGS.  But we need them in CFLAGS during configury.  So put them
--# in both places for now and restore CFLAGS at the end of config.
--save_CFLAGS="$CFLAGS"
--
- # Find other programs we need.
- AC_CHECK_TOOL(AR, ar)
- AC_CHECK_TOOL(NM, nm)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 06c4a0d..c66ebe8 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+47	????
+
+	- 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
+
 46	17 February 2025
 
 	- 81_all_PR118097-ipa-cp-Perform-operations-in-the-appropriate-types-P.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-13 10:08 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-13 10:08 UTC (permalink / raw
  To: gentoo-commits
commit:     ae822d007a7120fa5856a3fe8d5f90e97eba0b55
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Mar 13 10:07:37 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Mar 13 10:08:10 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ae822d00
15.0.0: add realpath hack for C++ modules JSON location
Bug: https://gcc.gnu.org/PR119266
Bug: https://bugs.gentoo.org/948394
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-contrib-make-relpath.sh-use-GNU-realpath.patch | 33 ++++++++++++++++++++++
 15.0.0/gentoo/README.history                       |  1 +
 2 files changed, 34 insertions(+)
diff --git a/15.0.0/gentoo/35_all_PR119266-contrib-make-relpath.sh-use-GNU-realpath.patch b/15.0.0/gentoo/35_all_PR119266-contrib-make-relpath.sh-use-GNU-realpath.patch
new file mode 100644
index 0000000..8278fc4
--- /dev/null
+++ b/15.0.0/gentoo/35_all_PR119266-contrib-make-relpath.sh-use-GNU-realpath.patch
@@ -0,0 +1,33 @@
+From 0a2fe8f7a000a13005688aea980b90befe917a8e Mon Sep 17 00:00:00 2001
+Message-ID: <0a2fe8f7a000a13005688aea980b90befe917a8e.1741860425.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Thu, 13 Mar 2025 10:06:29 +0000
+Subject: [PATCH] contrib: make relpath.sh use GNU realpath
+
+contrib/ChangeLog:
+	PR libstdc++/119266
+
+        * relpath.sh: Use GNU realpath.
+---
+ contrib/relpath.sh | 3 +++
+ 1 file changed, 3 insertions(+)
+
+diff --git a/contrib/relpath.sh b/contrib/relpath.sh
+index 1b329fc04a78..3930b7730d0b 100755
+--- a/contrib/relpath.sh
++++ b/contrib/relpath.sh
+@@ -10,6 +10,9 @@ fi
+ from="${1%%/}"
+ to="${2%%/}"
+ 
++# XXX: Hack for https://gcc.gnu.org/PR119266
++exec realpath --relative-to="${from}" "${to}"
++
+ # The parent directory of a pathname, handling ..
+ parent() {
+     name=$(basename "$1")
+
+base-commit: d8a3944b440777d2d6fb4a9f456189a0dc439ec8
+-- 
+2.48.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index c66ebe8..9e5a944 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 47	????
 
+	+ 35_all_PR119266-contrib-make-relpath.sh-use-GNU-realpath.patch
 	- 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
 
 46	17 February 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-13 16:48 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-13 16:48 UTC (permalink / raw
  To: gentoo-commits
commit:     c80eba1e1f25987e05fb9724b199fdb464becb37
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Mar 13 16:48:39 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Mar 13 16:48:44 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=c80eba1e
Revert "15.0.0: add realpath hack for C++ modules JSON location"
This reverts commit ae822d007a7120fa5856a3fe8d5f90e97eba0b55.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-contrib-make-relpath.sh-use-GNU-realpath.patch | 33 ----------------------
 15.0.0/gentoo/README.history                       |  1 -
 2 files changed, 34 deletions(-)
diff --git a/15.0.0/gentoo/35_all_PR119266-contrib-make-relpath.sh-use-GNU-realpath.patch b/15.0.0/gentoo/35_all_PR119266-contrib-make-relpath.sh-use-GNU-realpath.patch
deleted file mode 100644
index 8278fc4..0000000
--- a/15.0.0/gentoo/35_all_PR119266-contrib-make-relpath.sh-use-GNU-realpath.patch
+++ /dev/null
@@ -1,33 +0,0 @@
-From 0a2fe8f7a000a13005688aea980b90befe917a8e Mon Sep 17 00:00:00 2001
-Message-ID: <0a2fe8f7a000a13005688aea980b90befe917a8e.1741860425.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Thu, 13 Mar 2025 10:06:29 +0000
-Subject: [PATCH] contrib: make relpath.sh use GNU realpath
-
-contrib/ChangeLog:
-	PR libstdc++/119266
-
-        * relpath.sh: Use GNU realpath.
----
- contrib/relpath.sh | 3 +++
- 1 file changed, 3 insertions(+)
-
-diff --git a/contrib/relpath.sh b/contrib/relpath.sh
-index 1b329fc04a78..3930b7730d0b 100755
---- a/contrib/relpath.sh
-+++ b/contrib/relpath.sh
-@@ -10,6 +10,9 @@ fi
- from="${1%%/}"
- to="${2%%/}"
- 
-+# XXX: Hack for https://gcc.gnu.org/PR119266
-+exec realpath --relative-to="${from}" "${to}"
-+
- # The parent directory of a pathname, handling ..
- parent() {
-     name=$(basename "$1")
-
-base-commit: d8a3944b440777d2d6fb4a9f456189a0dc439ec8
--- 
-2.48.1
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 9e5a944..c66ebe8 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,5 @@
 47	????
 
-	+ 35_all_PR119266-contrib-make-relpath.sh-use-GNU-realpath.patch
 	- 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
 
 46	17 February 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-14 13:37 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-14 13:37 UTC (permalink / raw
  To: gentoo-commits
commit:     117d5d309ef1c5e11687e9e0a7e2965dcd9e1a1e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 14 13:37:16 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar 14 13:37:16 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=117d5d30
15.0.0: fix linux (and libtiff) build
Bug: https://gcc.gnu.org/PR119287
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/77_all_PR119287-linux.patch | 28 ++++++++++++++++++++++++++++
 15.0.0/gentoo/README.history              |  1 +
 2 files changed, 29 insertions(+)
diff --git a/15.0.0/gentoo/77_all_PR119287-linux.patch b/15.0.0/gentoo/77_all_PR119287-linux.patch
new file mode 100644
index 0000000..916edfa
--- /dev/null
+++ b/15.0.0/gentoo/77_all_PR119287-linux.patch
@@ -0,0 +1,28 @@
+From f58aa2cfa49c226f7233995e5359954512ee97c0 Mon Sep 17 00:00:00 2001
+Message-ID: <f58aa2cfa49c226f7233995e5359954512ee97c0.1741959406.git.sam@gentoo.org>
+From: Sam James <sam@gentoo.org>
+Date: Fri, 14 Mar 2025 13:36:44 +0000
+Subject: [PATCH] PR119287
+
+---
+ gcc/match.pd | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/gcc/match.pd b/gcc/match.pd
+index 89612d1b15b6..98f637373242 100644
+--- a/gcc/match.pd
++++ b/gcc/match.pd
+@@ -5284,7 +5284,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
+ 	 || tree_int_cst_sgn (@2) >= 0)
+ 	&& wi::to_wide (@3) == wi::set_bit_in_zero (shift, prec))
+     (with { auto mask = wide_int::from (wi::to_wide (@2), prec, UNSIGNED); }
+-     (bit_and @0 { wide_int_to_tree (type, mask << shift); }))))))
++     (bit_and (convert @0) { wide_int_to_tree (type, mask << shift); }))))))
+ 
+ /* ~(~X >> Y) -> X >> Y (for arithmetic shift).  */
+ (simplify
+
+base-commit: 5abe571e0276fafcc6eed27c27abb28943e67c6f
+-- 
+2.48.1
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index c66ebe8..0bfc61e 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 47	????
 
+	+ 77_all_PR119287-linux.patch
 	- 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
 
 46	17 February 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-14 14:46 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-14 14:46 UTC (permalink / raw
  To: gentoo-commits
commit:     b9beff3cec9cc2874fb8f6c9ac24648d7f44a06d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 14 14:46:33 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar 14 14:46:43 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b9beff3c
15.0.0: drop upstream patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/77_all_PR119287-linux.patch | 28 ----------------------------
 15.0.0/gentoo/README.history              |  1 -
 2 files changed, 29 deletions(-)
diff --git a/15.0.0/gentoo/77_all_PR119287-linux.patch b/15.0.0/gentoo/77_all_PR119287-linux.patch
deleted file mode 100644
index 916edfa..0000000
--- a/15.0.0/gentoo/77_all_PR119287-linux.patch
+++ /dev/null
@@ -1,28 +0,0 @@
-From f58aa2cfa49c226f7233995e5359954512ee97c0 Mon Sep 17 00:00:00 2001
-Message-ID: <f58aa2cfa49c226f7233995e5359954512ee97c0.1741959406.git.sam@gentoo.org>
-From: Sam James <sam@gentoo.org>
-Date: Fri, 14 Mar 2025 13:36:44 +0000
-Subject: [PATCH] PR119287
-
----
- gcc/match.pd | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-diff --git a/gcc/match.pd b/gcc/match.pd
-index 89612d1b15b6..98f637373242 100644
---- a/gcc/match.pd
-+++ b/gcc/match.pd
-@@ -5284,7 +5284,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
- 	 || tree_int_cst_sgn (@2) >= 0)
- 	&& wi::to_wide (@3) == wi::set_bit_in_zero (shift, prec))
-     (with { auto mask = wide_int::from (wi::to_wide (@2), prec, UNSIGNED); }
--     (bit_and @0 { wide_int_to_tree (type, mask << shift); }))))))
-+     (bit_and (convert @0) { wide_int_to_tree (type, mask << shift); }))))))
- 
- /* ~(~X >> Y) -> X >> Y (for arithmetic shift).  */
- (simplify
-
-base-commit: 5abe571e0276fafcc6eed27c27abb28943e67c6f
--- 
-2.48.1
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 0bfc61e..c66ebe8 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,5 @@
 47	????
 
-	+ 77_all_PR119287-linux.patch
 	- 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
 
 46	17 February 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-16 22:37 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-16 22:37 UTC (permalink / raw
  To: gentoo-commits
commit:     e36bfd9d8fde238e78a3ea7aacac14d2953f25ce
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Mar 16 22:36:55 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Mar 16 22:36:55 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=e36bfd9d
15.0.0: cut patchset 47
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index c66ebe8..30853ec 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-47	????
+47	16 March 2025
 
 	- 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-20  1:59 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-20  1:59 UTC (permalink / raw
  To: gentoo-commits
commit:     655d963e32c52ae1e34dee7aec12099cd34f5ff5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Mar 20 01:58:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Mar 20 01:59:07 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=655d963e
15.0.0: disable [[clang::musttail]] for now
Breaks building FF and protobuf for now (not clear why this only shows
up now, seems to be an unfortunate coincidence).
Bug: https://gcc.gnu.org/PR119376
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../77_all_PR119376-Disable-clang-musttail.patch   | 198 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   4 +
 2 files changed, 202 insertions(+)
diff --git a/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch b/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch
new file mode 100644
index 0000000..f7f630b
--- /dev/null
+++ b/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch
@@ -0,0 +1,198 @@
+From 592f60bef27cb60ea6405ca8603449fc4d92e640 Mon Sep 17 00:00:00 2001
+Message-ID: <592f60bef27cb60ea6405ca8603449fc4d92e640.1742435883.git.sam@gentoo.org>
+From: Andi Kleen <ak@gcc.gnu.org>
+Date: Wed, 19 Mar 2025 18:31:02 -0700
+Subject: [PATCH] PR119376: Disable clang musttail
+
+There are multiple reports (see PR 119376) now where semantic differences
+in the gcc musttail implementation break existing programs written for the clang
+variant.
+
+Even though that can be all hopefully fixed eventually,
+for the gcc 15 release it seems safer to disable clang::musttail,
+and only keep gnu::musttail.
+
+That means that programs that use __has_c_attribute to check for
+clang::musttail must opt-in explicitly.
+
+Reported-by: Sam James
+
+gcc/c/ChangeLog:
+
+	PR ipa/119376
+	* c-parser.cc (c_parser_handle_musttail): Drop clang namespace
+	check.
+
+gcc/cp/ChangeLog:
+
+	PR ipa/119376
+	* parser.cc (cp_parser_jump_statement): Drop clang namespace
+	check.
+
+gcc/ChangeLog:
+
+	PR ipa/119376
+	* doc/extend.texi: Drop clang::musttail reference.
+
+gcc/testsuite/ChangeLog:
+
+PR ipa/119376
+	* c-c++-common/musttail23.c: Don't use clang::musttail
+	* c-c++-common/musttail24.c: Dito.
+	* c-c++-common/musttail3.c: Dito.
+	* g++.dg/musttail14.C: Dito.
+---
+ gcc/c/c-parser.cc                       |  5 -----
+ gcc/cp/parser.cc                        |  6 ------
+ gcc/doc/extend.texi                     |  2 +-
+ gcc/testsuite/c-c++-common/musttail23.c | 10 +++++-----
+ gcc/testsuite/c-c++-common/musttail24.c |  6 ------
+ gcc/testsuite/c-c++-common/musttail3.c  |  6 +++---
+ gcc/testsuite/g++.dg/musttail14.C       |  4 ++--
+ 7 files changed, 11 insertions(+), 28 deletions(-)
+
+diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
+index d49d5c58659f..79654448acaa 100644
+--- a/gcc/c/c-parser.cc
++++ b/gcc/c/c-parser.cc
+@@ -7409,11 +7409,6 @@ c_parser_handle_musttail (c_parser *parser, tree std_attrs, attr_state &attr)
+ 	  std_attrs = remove_attribute ("gnu", "musttail", std_attrs);
+ 	  attr.musttail_p = true;
+ 	}
+-      if (lookup_attribute ("clang", "musttail", std_attrs))
+-	{
+-	  std_attrs = remove_attribute ("clang", "musttail", std_attrs);
+-	  attr.musttail_p = true;
+-	}
+     }
+   return std_attrs;
+ }
+diff --git a/gcc/cp/parser.cc b/gcc/cp/parser.cc
+index 2fb1dc5992d4..da7700b55c64 100644
+--- a/gcc/cp/parser.cc
++++ b/gcc/cp/parser.cc
+@@ -15342,12 +15342,6 @@ cp_parser_jump_statement (cp_parser* parser, tree &std_attrs)
+ 		musttail_p = true;
+ 		std_attrs = remove_attribute ("gnu", "musttail", std_attrs);
+ 	      }
+-	    /* Support this for compatibility.  */
+-	    if (lookup_attribute ("clang", "musttail", std_attrs))
+-	      {
+-		musttail_p = true;
+-		std_attrs = remove_attribute ("clang", "musttail", std_attrs);
+-	      }
+ 
+ 	    tree ret_expr = expr;
+ 	    if (ret_expr && TREE_CODE (ret_expr) == TARGET_EXPR)
+diff --git a/gcc/doc/extend.texi b/gcc/doc/extend.texi
+index b919df914648..50f95e968ff9 100644
+--- a/gcc/doc/extend.texi
++++ b/gcc/doc/extend.texi
+@@ -10241,7 +10241,7 @@ have to optimize it to just @code{return 42 + 42;}.
+ @cindex @code{musttail} statement attribute
+ @item musttail
+ 
+-The @code{gnu::musttail} or @code{clang::musttail} standard attribute
++The @code{gnu::musttail} standard attribute
+ or @code{musttail} GNU attribute can be applied to a @code{return} statement
+ with a return-value expression that is a function call.  It asserts that the
+ call must be a tail call that does not allocate extra stack space, so it is
+diff --git a/gcc/testsuite/c-c++-common/musttail23.c b/gcc/testsuite/c-c++-common/musttail23.c
+index d2ba70b03250..1ceab1165129 100644
+--- a/gcc/testsuite/c-c++-common/musttail23.c
++++ b/gcc/testsuite/c-c++-common/musttail23.c
+@@ -19,10 +19,10 @@ foo (int x)
+     [[gnu::musttail (1, "", 3)]] return bar ();		/* { dg-error "'musttail' attribute does not take any arguments" } */
+ 							/* { dg-error "expected" "" { target c } .-1 } */
+   if (x == 3)
+-    [[clang::musttail (1)]] return bar ();		/* { dg-error "'musttail' attribute does not take any arguments" } */
++    [[gnu::musttail (1)]] return bar ();		/* { dg-error "'musttail' attribute does not take any arguments" } */
+ 							/* { dg-error "expected" "" { target c } .-1 } */
+   if (x == 4)
+-    [[clang::musttail (1, "", 3)]] return bar ();	/* { dg-error "'musttail' attribute does not take any arguments" } */
++    [[gnu::musttail (1, "", 3)]] return bar ();	/* { dg-error "'musttail' attribute does not take any arguments" } */
+ 							/* { dg-error "expected" "" { target c } .-1 } */
+   if (x == 5)
+     __attribute__((fallthrough, musttail)) return bar (); /* { dg-warning "attribute 'musttail' mixed with other attributes on 'return' statement" "" { target c } } */
+@@ -32,14 +32,14 @@ foo (int x)
+     [[fallthrough]] [[gnu::musttail]] return bar ();	/* { dg-warning "'fallthrough' attribute ignored" "" { target c } } */
+ 							/* { dg-warning "attributes at the beginning of statement are ignored" "" { target c++ } .-1 } */
+   if (x == 7)
+-    [[clang::musttail, fallthrough]] return bar ();	/* { dg-warning "'fallthrough' attribute ignored" "" { target c } } */
++    [[gnu::musttail, fallthrough]] return bar ();	/* { dg-warning "'fallthrough' attribute ignored" "" { target c } } */
+ 							/* { dg-warning "attributes at the beginning of statement are ignored" "" { target c++ } .-1 } */
+   if (x == 8)
+     __attribute__((musttail, musttail)) return bar ();
+   if (x == 9)
+     [[gnu::musttail, gnu::musttail]] return bar ();
+   if (x == 10)
+-    [[clang::musttail]] [[clang::musttail]] return bar ();
++    [[gnu::musttail]] [[gnu::musttail]] return bar ();
+   if (x == 11)
+-    [[clang::musttail]] [[gnu::musttail]] return bar ();
++    [[gnu::musttail]] [[gnu::musttail]] return bar ();
+ }
+diff --git a/gcc/testsuite/c-c++-common/musttail24.c b/gcc/testsuite/c-c++-common/musttail24.c
+index 10c2d3f188d8..26b8dbfb4c8e 100644
+--- a/gcc/testsuite/c-c++-common/musttail24.c
++++ b/gcc/testsuite/c-c++-common/musttail24.c
+@@ -8,14 +8,8 @@
+ #if !__has_cpp_attribute (gnu::musttail)
+ #error missing gnu::musttail attribute
+ #endif
+-#if !__has_cpp_attribute (clang::musttail)
+-#error missing clang::musttail attribute
+-#endif
+ #else
+ #if !__has_c_attribute (gnu::musttail)
+ #error missing gnu::musttail attribute
+ #endif
+-#if !__has_c_attribute (clang::musttail)
+-#error missing clang::musttail attribute
+-#endif
+ #endif
+diff --git a/gcc/testsuite/c-c++-common/musttail3.c b/gcc/testsuite/c-c++-common/musttail3.c
+index 7499fd6460b4..daedca28852a 100644
+--- a/gcc/testsuite/c-c++-common/musttail3.c
++++ b/gcc/testsuite/c-c++-common/musttail3.c
+@@ -11,7 +11,7 @@ struct str
+ cstruct (int x)
+ {
+   if (x < 10)
+-    [[clang::musttail]] return cstruct (x + 1);
++    [[gnu::musttail]] return cstruct (x + 1);
+   return ((struct str){ x, 0 });
+ }
+ 
+@@ -19,11 +19,11 @@ int
+ foo (int x)
+ {
+   if (x < 10)
+-    [[clang::musttail]] return foo2 (x, 29);
++    [[gnu::musttail]] return foo2 (x, 29);
+   if (x < 100)
+     {
+       int k = foo (x + 1);
+-      [[clang::musttail]] return k;	/* { dg-error "cannot tail-call: " } */
++      [[gnu::musttail]] return k;	/* { dg-error "cannot tail-call: " } */
+     }
+   return x;
+ }
+diff --git a/gcc/testsuite/g++.dg/musttail14.C b/gcc/testsuite/g++.dg/musttail14.C
+index 810b45546d61..e4764a3bc03b 100644
+--- a/gcc/testsuite/g++.dg/musttail14.C
++++ b/gcc/testsuite/g++.dg/musttail14.C
+@@ -58,8 +58,8 @@ garply (int x)
+     case 3:
+       __attribute__(()) [[gnu::musttail]] __attribute__(()) [[]] __attribute__(()) return qux (45);
+     case 4:
+-      [[]] __attribute__(()) [[clang::musttail]] __attribute__(()) [[]] return corge (46);
++      [[]] __attribute__(()) [[gnu::musttail]] __attribute__(()) [[]] return corge (46);
+     default:
+-      __attribute__(()) [[clang::musttail]] __attribute__(()) [[]] __attribute__(()) return freddy (47);
++      __attribute__(()) [[gnu::musttail]] __attribute__(()) [[]] __attribute__(()) return freddy (47);
+     }
+ }
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 30853ec..42281c1 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+48	????
+
+	+ 77_all_PR119376-Disable-clang-musttail.patch
+
 47	16 March 2025
 
 	- 80_all_PR81358-Enable-automatic-linking-of-libatomic.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-20  1:59 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-20  1:59 UTC (permalink / raw
  To: gentoo-commits
commit:     9c71a763b2beea05b6c9f13fd35a11ffd279e283
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Mar 20 01:59:29 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Mar 20 01:59:29 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=9c71a763
15.0.0: add upstream link for musttail patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch b/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch
index f7f630b..3af4ab4 100644
--- a/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch
+++ b/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch
@@ -1,3 +1,5 @@
+https://inbox.sourceware.org/gcc-patches/20250320013102.1336516-1-andi@firstfloor.org/
+
 From 592f60bef27cb60ea6405ca8603449fc4d92e640 Mon Sep 17 00:00:00 2001
 Message-ID: <592f60bef27cb60ea6405ca8603449fc4d92e640.1742435883.git.sam@gentoo.org>
 From: Andi Kleen <ak@gcc.gnu.org>
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-20 22:08 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-20 22:08 UTC (permalink / raw
  To: gentoo-commits
commit:     e9845265a93c61733751546d578f66396a078129
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Mar 20 22:07:48 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Mar 20 22:08:13 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=e9845265
15.0.0: add shrink-wrapping + miscompilation fix
... from Jakub.
Bug: https://gcc.gnu.org/PR118615
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/78_all_PR118615.patch | 111 ++++++++++++++++++++++++++++++++++++
 15.0.0/gentoo/README.history        |   1 +
 2 files changed, 112 insertions(+)
diff --git a/15.0.0/gentoo/78_all_PR118615.patch b/15.0.0/gentoo/78_all_PR118615.patch
new file mode 100644
index 0000000..4c72699
--- /dev/null
+++ b/15.0.0/gentoo/78_all_PR118615.patch
@@ -0,0 +1,111 @@
+--- a/gcc/lra-constraints.cc	2025-03-19 19:20:41.644440691 +0100
++++ b/gcc/lra-constraints.cc	2025-03-20 18:40:04.188299643 +0100
+@@ -152,6 +152,9 @@ static machine_mode curr_operand_mode[MA
+    (e.g. constant) and whose subreg is given operand of the current
+    insn.  VOIDmode in all other cases.  */
+ static machine_mode original_subreg_reg_mode[MAX_RECOG_OPERANDS];
++/* The first call insn after curr_insn within the EBB during inherit_in_ebb
++   or NULL outside of that function.  */
++static rtx_insn *first_call_insn;
+ 
+ 
+ 
+@@ -6373,12 +6376,26 @@ split_reg (bool before_p, int original_r
+   lra_process_new_insns (as_a <rtx_insn *> (usage_insn),
+ 			 after_p ? NULL : restore,
+ 			 after_p ? restore : NULL,
+-			 call_save_p
+-			 ?  "Add reg<-save" : "Add reg<-split");
+-  lra_process_new_insns (insn, before_p ? save : NULL,
+-			 before_p ? NULL : save,
+-			 call_save_p
+-			 ?  "Add save<-reg" : "Add split<-reg");
++			 call_save_p ? "Add reg<-save" : "Add reg<-split");
++  if (call_save_p
++      && first_call_insn != NULL
++      && BLOCK_FOR_INSN (first_call_insn) != BLOCK_FOR_INSN (insn))
++    /* PR116028: If original_regno is a pseudo that has been assigned a
++       call-save hard register, then emit the spill insn before the call
++       insn 'first_call_insn' instead of adjacent to 'insn'.  If 'insn'
++       and 'first_call_insn' belong to the same EBB but to two separate
++       BBs, and if 'insn' is present in the entry BB, then generating the
++       spill insn in the entry BB can prevent shrink wrap from happening.
++       This is because the spill insn references the stack pointer and
++       hence the prolog gets generated in the entry BB itself.  It is
++       also more efficient to generate the spill before
++       'first_call_insn' as the spill now occurs only in the path
++       containing the call.  */
++    lra_process_new_insns (first_call_insn, save, NULL, "Add save<-reg");
++  else
++    lra_process_new_insns (insn, before_p ? save : NULL,
++			   before_p ? NULL : save,
++			   call_save_p ? "Add save<-reg" : "Add split<-reg");
+   if (nregs > 1 || original_regno < FIRST_PSEUDO_REGISTER)
+     /* If we are trying to split multi-register.  We should check
+        conflicts on the next assignment sub-pass.  IRA can allocate on
+@@ -6484,7 +6501,7 @@ split_if_necessary (int regno, machine_m
+ 		&& (INSN_UID (XEXP (next_usage_insns, 0)) < max_uid)))
+ 	&& need_for_split_p (potential_reload_hard_regs, regno + i)
+ 	&& split_reg (before_p, regno + i, insn, next_usage_insns, NULL))
+-    res = true;
++      res = true;
+   return res;
+ }
+ 
+@@ -6862,6 +6879,7 @@ inherit_in_ebb (rtx_insn *head, rtx_insn
+   last_processed_bb = NULL;
+   CLEAR_HARD_REG_SET (potential_reload_hard_regs);
+   live_hard_regs = eliminable_regset | lra_no_alloc_regs;
++  first_call_insn = NULL;
+   /* We don't process new insns generated in the loop.	*/
+   for (curr_insn = tail; curr_insn != PREV_INSN (head); curr_insn = prev_insn)
+     {
+@@ -7074,6 +7092,7 @@ inherit_in_ebb (rtx_insn *head, rtx_insn
+ 	      last_call_for_abi[callee_abi.id ()] = calls_num;
+ 	      full_and_partial_call_clobbers
+ 		|= callee_abi.full_and_partial_reg_clobbers ();
++	      first_call_insn = curr_insn;
+ 	      if ((cheap = find_reg_note (curr_insn,
+ 					  REG_RETURNED, NULL_RTX)) != NULL_RTX
+ 		  && ((cheap = XEXP (cheap, 0)), true)
+@@ -7142,6 +7161,7 @@ inherit_in_ebb (rtx_insn *head, rtx_insn
+ 		    {
+ 		      bool before_p;
+ 		      rtx_insn *use_insn = curr_insn;
++		      rtx_insn *prev_insn = PREV_INSN (curr_insn);
+ 
+ 		      before_p = (JUMP_P (curr_insn)
+ 				  || (CALL_P (curr_insn) && reg->type == OP_IN));
+@@ -7156,7 +7176,7 @@ inherit_in_ebb (rtx_insn *head, rtx_insn
+ 			  change_p = true;
+ 			  /* Invalidate. */
+ 			  usage_insns[src_regno].check = 0;
+-			  if (before_p)
++			  if (before_p && PREV_INSN (curr_insn) != prev_insn)
+ 			    use_insn = PREV_INSN (curr_insn);
+ 			}
+ 		      if (NONDEBUG_INSN_P (curr_insn))
+@@ -7278,6 +7298,7 @@ inherit_in_ebb (rtx_insn *head, rtx_insn
+ 	    }
+ 	}
+     }
++  first_call_insn = NULL;
+   return change_p;
+ }
+ 
+--- a/gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c	2024-07-01 11:28:23.278230620 +0200
++++ b/gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c	2025-03-20 19:50:49.369486995 +0100
+@@ -26,4 +26,4 @@ bar (long a)
+ 
+ /* { dg-final { scan-rtl-dump "Will split live ranges of parameters" "ira" } } */
+ /* { dg-final { scan-rtl-dump "Split live-range of register" "ira" { xfail { ! aarch64*-*-* } } } } */
+-/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue" { xfail powerpc*-*-* } } } */
++/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue" } } */
+--- a/gcc/testsuite/gcc.dg/pr10474.c	2025-03-20 19:50:49.379486857 +0100
++++ b/gcc/testsuite/gcc.dg/pr10474.c	2025-03-20 19:51:30.150929050 +0100
+@@ -13,4 +13,4 @@ void f(int *i)
+ }
+ 
+ /* XFAIL due to PR70681.  */ 
+-/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue"  { xfail arm*-*-* powerpc*-*-* } } } */
++/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue"  { xfail arm*-*-* } } } */
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 42281c1..f55d569 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 48	????
 
 	+ 77_all_PR119376-Disable-clang-musttail.patch
+	+ 78_all_PR118615.patch
 
 47	16 March 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-21  6:07 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-21  6:07 UTC (permalink / raw
  To: gentoo-commits
commit:     b174b37b1211411d7b7a7d7c830da86f19d9ecb5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 21 06:03:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar 21 06:03:09 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b174b37b
15.0.0: add arm32 neon shift patch
Bug: https://gcc.gnu.org/PR117811
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/79_all_PR117811-arm-neon-shift.patch | 96 ++++++++++++++++++++++
 15.0.0/gentoo/README.history                       |  1 +
 2 files changed, 97 insertions(+)
diff --git a/15.0.0/gentoo/79_all_PR117811-arm-neon-shift.patch b/15.0.0/gentoo/79_all_PR117811-arm-neon-shift.patch
new file mode 100644
index 0000000..f2bb73a
--- /dev/null
+++ b/15.0.0/gentoo/79_all_PR117811-arm-neon-shift.patch
@@ -0,0 +1,96 @@
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=117811#c20
+
+From 5256e5419d07f7313fe661901b9a4821b3d47764 Mon Sep 17 00:00:00 2001
+From: Andrew Pinski <quic_apinski@quicinc.com>
+Date: Wed, 19 Mar 2025 16:02:12 -0700
+Subject: [PATCH] Fix expand_binop_directly in some cases [PR117811]
+
+The problem here is that when dealing with adding the equal note,
+we decide to call expand_binop directly but before we do that we
+call delete_insns_since with the last argument. The problem is that
+deletes too much and falls over. So instead we need to delete only
+up to what was done at the point of the call to expand_binop_directly
+
+Bootstrapped and tested on x86_64-linux-gnu.  Also Christophe Lyon tested
+it on arm-linux-gnueabihf.
+
+	PR middle-end/117811
+
+gcc/ChangeLog:
+
+	* optabs.cc (expand_binop_directly): Delete only what was done
+	since the entry before calling expand_binop.
+
+gcc/testsuite/ChangeLog:
+
+	* c-c++-common/torture/pr117811-1.c: New test.
+
+Signed-off-by: Andrew Pinski <quic_apinski@quicinc.com>
+---
+ gcc/optabs.cc                                 |  3 +-
+ .../c-c++-common/torture/pr117811-1.c         | 32 +++++++++++++++++++
+ 2 files changed, 34 insertions(+), 1 deletion(-)
+ create mode 100644 gcc/testsuite/c-c++-common/torture/pr117811-1.c
+
+diff --git a/gcc/optabs.cc b/gcc/optabs.cc
+index 36f2e6af8b5..366df985147 100644
+--- a/gcc/optabs.cc
++++ b/gcc/optabs.cc
+@@ -1380,6 +1380,7 @@ expand_binop_directly (enum insn_code icode, machine_mode mode, optab binoptab,
+   rtx_insn *pat;
+   rtx xop0 = op0, xop1 = op1;
+   bool canonicalize_op1 = false;
++  rtx_insn *entry_last = get_last_insn ();
+ 
+   /* If it is a commutative operator and the modes would match
+      if we would swap the operands, we can save the conversions.  */
+@@ -1466,7 +1467,7 @@ expand_binop_directly (enum insn_code icode, machine_mode mode, optab binoptab,
+ 			       optab_to_code (binoptab),
+ 			       ops[1].value, ops[2].value, mode0))
+ 	{
+-	  delete_insns_since (last);
++	  delete_insns_since (entry_last);
+ 	  return expand_binop (mode, binoptab, op0, op1, NULL_RTX,
+ 			       unsignedp, methods);
+ 	}
+diff --git a/gcc/testsuite/c-c++-common/torture/pr117811-1.c b/gcc/testsuite/c-c++-common/torture/pr117811-1.c
+new file mode 100644
+index 00000000000..a0558cbd0ae
+--- /dev/null
++++ b/gcc/testsuite/c-c++-common/torture/pr117811-1.c
+@@ -0,0 +1,32 @@
++/* { dg-do run } */
++
++/* PR middle-end/117811 */
++/* Tests that right shift on vectors work. */
++
++typedef int v4 __attribute__((vector_size(4*sizeof(int))));
++
++void buggy_shift( v4 *vec, int shift ) __attribute__((noipa));
++void buggy_shift( v4 *vec, int shift )
++{
++  v4 t = *vec;
++
++  if ( shift > 0 )
++  {
++    t = t >> shift;
++  }
++
++  *vec = t;
++}
++
++int main()
++{
++  v4 v = {0x0<<4, 0x1<<4, 2<<4, 3<<4};
++  v4 r = {0x0, 0x1, 2, 3};
++  int shift = 4;
++  buggy_shift(&v, shift);
++  for(int i = 0; i < 4; i++)
++    if (v[i] != r[i])
++      __builtin_abort();
++  return 0;
++}
++
+-- 
+2.43.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index f55d569..c3b9934 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -2,6 +2,7 @@
 
 	+ 77_all_PR119376-Disable-clang-musttail.patch
 	+ 78_all_PR118615.patch
+	+ 79_all_PR117811-arm-neon-shift.patch
 
 47	16 March 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-21  8:51 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-21  8:51 UTC (permalink / raw
  To: gentoo-commits
commit:     c493acdcc2a518453dd85017be30a8071d4efe4d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 21 08:51:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar 21 08:51:23 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=c493acdc
15.0.0: refresh 78_all_PR118615.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/78_all_PR118615.patch | 62 ++++++++++++++++++++++++++++++-------
 1 file changed, 50 insertions(+), 12 deletions(-)
diff --git a/15.0.0/gentoo/78_all_PR118615.patch b/15.0.0/gentoo/78_all_PR118615.patch
index 4c72699..9ae8200 100644
--- a/15.0.0/gentoo/78_all_PR118615.patch
+++ b/15.0.0/gentoo/78_all_PR118615.patch
@@ -1,3 +1,21 @@
+2025-03-21  Surya Kumari Jangala  <jskumari@linux.ibm.com>
+	    Jakub Jelinek  <jakub@redhat.com>
+
+	PR rtl-optimization/116028
+	PR rtl-optimization/118615
+	* lra-constraints.cc (first_call_insn): New variable.
+	(split_reg): Spill register before first_call_insn if call_save_p
+	and the call is in a different bb in the ebb.
+	(split_if_necessary): Formatting fix.
+	(inherit_in_ebb): Set first_call_insn when handling a CALL_INSN.
+	For successful split_if_necessary with before_p, only change
+	use_insn if it emitted any new instructions before curr_insn.
+	Clear first_call_insn before returning.
+	
+	* gcc.dg/ira-shrinkwrap-prep-1.c: Remove xfail for powerpc.
+	* gcc.dg/pr10474.c: Remove xfail for powerpc and arm.
+	* gcc.dg/pr118615.c: New test.
+
 --- a/gcc/lra-constraints.cc	2025-03-19 19:20:41.644440691 +0100
 +++ b/gcc/lra-constraints.cc	2025-03-20 18:40:04.188299643 +0100
 @@ -152,6 +152,9 @@ static machine_mode curr_operand_mode[MA
@@ -52,14 +70,6 @@
    return res;
  }
  
-@@ -6862,6 +6879,7 @@ inherit_in_ebb (rtx_insn *head, rtx_insn
-   last_processed_bb = NULL;
-   CLEAR_HARD_REG_SET (potential_reload_hard_regs);
-   live_hard_regs = eliminable_regset | lra_no_alloc_regs;
-+  first_call_insn = NULL;
-   /* We don't process new insns generated in the loop.	*/
-   for (curr_insn = tail; curr_insn != PREV_INSN (head); curr_insn = prev_insn)
-     {
 @@ -7074,6 +7092,7 @@ inherit_in_ebb (rtx_insn *head, rtx_insn
  	      last_call_for_abi[callee_abi.id ()] = calls_num;
  	      full_and_partial_call_clobbers
@@ -102,10 +112,38 @@
 -/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue" { xfail powerpc*-*-* } } } */
 +/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue" } } */
 --- a/gcc/testsuite/gcc.dg/pr10474.c	2025-03-20 19:50:49.379486857 +0100
-+++ b/gcc/testsuite/gcc.dg/pr10474.c	2025-03-20 19:51:30.150929050 +0100
-@@ -13,4 +13,4 @@ void f(int *i)
++++ b/gcc/testsuite/gcc.dg/pr10474.c	2025-03-21 09:33:23.808051052 +0100
+@@ -12,5 +12,4 @@ void f(int *i)
+ 	}
  }
  
- /* XFAIL due to PR70681.  */ 
+-/* XFAIL due to PR70681.  */ 
 -/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue"  { xfail arm*-*-* powerpc*-*-* } } } */
-+/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue"  { xfail arm*-*-* } } } */
++/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue" } } */
+--- a/gcc/testsuite/gcc.dg/pr118615.c	2025-03-21 09:44:26.502876412 +0100
++++ b/gcc/testsuite/gcc.dg/pr118615.c	2025-03-21 09:45:22.447104189 +0100
+@@ -0,0 +1,24 @@
++/* PR rtl-optimization/118615 */
++/* { dg-do compile { target scheduling } } */
++/* { dg-options "-O2 -fcompare-debug -fschedule-insns" } */
++
++void foo (void);
++void bar (int);
++void baz (int *);
++int j;
++
++void
++qux (int k, int *m)
++{
++  int n;
++  if (k)
++    {
++      foo ();
++      if (m)
++	{
++	  bar (j);
++	  baz (m);
++	}
++    }
++  baz (&n);
++}
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-21 11:20 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-21 11:20 UTC (permalink / raw
  To: gentoo-commits
commit:     ebea0f72bf6bcc9c53105a689beb6263047b35c8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 21 11:19:57 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar 21 11:19:57 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ebea0f72
15.0.0: drop musttail workaround
Jakub's committed several fixes now, so let's see what falls out.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../77_all_PR119376-Disable-clang-musttail.patch   | 200 ---------------------
 15.0.0/gentoo/README.history                       |   1 -
 2 files changed, 201 deletions(-)
diff --git a/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch b/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch
deleted file mode 100644
index 3af4ab4..0000000
--- a/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch
+++ /dev/null
@@ -1,200 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/20250320013102.1336516-1-andi@firstfloor.org/
-
-From 592f60bef27cb60ea6405ca8603449fc4d92e640 Mon Sep 17 00:00:00 2001
-Message-ID: <592f60bef27cb60ea6405ca8603449fc4d92e640.1742435883.git.sam@gentoo.org>
-From: Andi Kleen <ak@gcc.gnu.org>
-Date: Wed, 19 Mar 2025 18:31:02 -0700
-Subject: [PATCH] PR119376: Disable clang musttail
-
-There are multiple reports (see PR 119376) now where semantic differences
-in the gcc musttail implementation break existing programs written for the clang
-variant.
-
-Even though that can be all hopefully fixed eventually,
-for the gcc 15 release it seems safer to disable clang::musttail,
-and only keep gnu::musttail.
-
-That means that programs that use __has_c_attribute to check for
-clang::musttail must opt-in explicitly.
-
-Reported-by: Sam James
-
-gcc/c/ChangeLog:
-
-	PR ipa/119376
-	* c-parser.cc (c_parser_handle_musttail): Drop clang namespace
-	check.
-
-gcc/cp/ChangeLog:
-
-	PR ipa/119376
-	* parser.cc (cp_parser_jump_statement): Drop clang namespace
-	check.
-
-gcc/ChangeLog:
-
-	PR ipa/119376
-	* doc/extend.texi: Drop clang::musttail reference.
-
-gcc/testsuite/ChangeLog:
-
-PR ipa/119376
-	* c-c++-common/musttail23.c: Don't use clang::musttail
-	* c-c++-common/musttail24.c: Dito.
-	* c-c++-common/musttail3.c: Dito.
-	* g++.dg/musttail14.C: Dito.
----
- gcc/c/c-parser.cc                       |  5 -----
- gcc/cp/parser.cc                        |  6 ------
- gcc/doc/extend.texi                     |  2 +-
- gcc/testsuite/c-c++-common/musttail23.c | 10 +++++-----
- gcc/testsuite/c-c++-common/musttail24.c |  6 ------
- gcc/testsuite/c-c++-common/musttail3.c  |  6 +++---
- gcc/testsuite/g++.dg/musttail14.C       |  4 ++--
- 7 files changed, 11 insertions(+), 28 deletions(-)
-
-diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
-index d49d5c58659f..79654448acaa 100644
---- a/gcc/c/c-parser.cc
-+++ b/gcc/c/c-parser.cc
-@@ -7409,11 +7409,6 @@ c_parser_handle_musttail (c_parser *parser, tree std_attrs, attr_state &attr)
- 	  std_attrs = remove_attribute ("gnu", "musttail", std_attrs);
- 	  attr.musttail_p = true;
- 	}
--      if (lookup_attribute ("clang", "musttail", std_attrs))
--	{
--	  std_attrs = remove_attribute ("clang", "musttail", std_attrs);
--	  attr.musttail_p = true;
--	}
-     }
-   return std_attrs;
- }
-diff --git a/gcc/cp/parser.cc b/gcc/cp/parser.cc
-index 2fb1dc5992d4..da7700b55c64 100644
---- a/gcc/cp/parser.cc
-+++ b/gcc/cp/parser.cc
-@@ -15342,12 +15342,6 @@ cp_parser_jump_statement (cp_parser* parser, tree &std_attrs)
- 		musttail_p = true;
- 		std_attrs = remove_attribute ("gnu", "musttail", std_attrs);
- 	      }
--	    /* Support this for compatibility.  */
--	    if (lookup_attribute ("clang", "musttail", std_attrs))
--	      {
--		musttail_p = true;
--		std_attrs = remove_attribute ("clang", "musttail", std_attrs);
--	      }
- 
- 	    tree ret_expr = expr;
- 	    if (ret_expr && TREE_CODE (ret_expr) == TARGET_EXPR)
-diff --git a/gcc/doc/extend.texi b/gcc/doc/extend.texi
-index b919df914648..50f95e968ff9 100644
---- a/gcc/doc/extend.texi
-+++ b/gcc/doc/extend.texi
-@@ -10241,7 +10241,7 @@ have to optimize it to just @code{return 42 + 42;}.
- @cindex @code{musttail} statement attribute
- @item musttail
- 
--The @code{gnu::musttail} or @code{clang::musttail} standard attribute
-+The @code{gnu::musttail} standard attribute
- or @code{musttail} GNU attribute can be applied to a @code{return} statement
- with a return-value expression that is a function call.  It asserts that the
- call must be a tail call that does not allocate extra stack space, so it is
-diff --git a/gcc/testsuite/c-c++-common/musttail23.c b/gcc/testsuite/c-c++-common/musttail23.c
-index d2ba70b03250..1ceab1165129 100644
---- a/gcc/testsuite/c-c++-common/musttail23.c
-+++ b/gcc/testsuite/c-c++-common/musttail23.c
-@@ -19,10 +19,10 @@ foo (int x)
-     [[gnu::musttail (1, "", 3)]] return bar ();		/* { dg-error "'musttail' attribute does not take any arguments" } */
- 							/* { dg-error "expected" "" { target c } .-1 } */
-   if (x == 3)
--    [[clang::musttail (1)]] return bar ();		/* { dg-error "'musttail' attribute does not take any arguments" } */
-+    [[gnu::musttail (1)]] return bar ();		/* { dg-error "'musttail' attribute does not take any arguments" } */
- 							/* { dg-error "expected" "" { target c } .-1 } */
-   if (x == 4)
--    [[clang::musttail (1, "", 3)]] return bar ();	/* { dg-error "'musttail' attribute does not take any arguments" } */
-+    [[gnu::musttail (1, "", 3)]] return bar ();	/* { dg-error "'musttail' attribute does not take any arguments" } */
- 							/* { dg-error "expected" "" { target c } .-1 } */
-   if (x == 5)
-     __attribute__((fallthrough, musttail)) return bar (); /* { dg-warning "attribute 'musttail' mixed with other attributes on 'return' statement" "" { target c } } */
-@@ -32,14 +32,14 @@ foo (int x)
-     [[fallthrough]] [[gnu::musttail]] return bar ();	/* { dg-warning "'fallthrough' attribute ignored" "" { target c } } */
- 							/* { dg-warning "attributes at the beginning of statement are ignored" "" { target c++ } .-1 } */
-   if (x == 7)
--    [[clang::musttail, fallthrough]] return bar ();	/* { dg-warning "'fallthrough' attribute ignored" "" { target c } } */
-+    [[gnu::musttail, fallthrough]] return bar ();	/* { dg-warning "'fallthrough' attribute ignored" "" { target c } } */
- 							/* { dg-warning "attributes at the beginning of statement are ignored" "" { target c++ } .-1 } */
-   if (x == 8)
-     __attribute__((musttail, musttail)) return bar ();
-   if (x == 9)
-     [[gnu::musttail, gnu::musttail]] return bar ();
-   if (x == 10)
--    [[clang::musttail]] [[clang::musttail]] return bar ();
-+    [[gnu::musttail]] [[gnu::musttail]] return bar ();
-   if (x == 11)
--    [[clang::musttail]] [[gnu::musttail]] return bar ();
-+    [[gnu::musttail]] [[gnu::musttail]] return bar ();
- }
-diff --git a/gcc/testsuite/c-c++-common/musttail24.c b/gcc/testsuite/c-c++-common/musttail24.c
-index 10c2d3f188d8..26b8dbfb4c8e 100644
---- a/gcc/testsuite/c-c++-common/musttail24.c
-+++ b/gcc/testsuite/c-c++-common/musttail24.c
-@@ -8,14 +8,8 @@
- #if !__has_cpp_attribute (gnu::musttail)
- #error missing gnu::musttail attribute
- #endif
--#if !__has_cpp_attribute (clang::musttail)
--#error missing clang::musttail attribute
--#endif
- #else
- #if !__has_c_attribute (gnu::musttail)
- #error missing gnu::musttail attribute
- #endif
--#if !__has_c_attribute (clang::musttail)
--#error missing clang::musttail attribute
--#endif
- #endif
-diff --git a/gcc/testsuite/c-c++-common/musttail3.c b/gcc/testsuite/c-c++-common/musttail3.c
-index 7499fd6460b4..daedca28852a 100644
---- a/gcc/testsuite/c-c++-common/musttail3.c
-+++ b/gcc/testsuite/c-c++-common/musttail3.c
-@@ -11,7 +11,7 @@ struct str
- cstruct (int x)
- {
-   if (x < 10)
--    [[clang::musttail]] return cstruct (x + 1);
-+    [[gnu::musttail]] return cstruct (x + 1);
-   return ((struct str){ x, 0 });
- }
- 
-@@ -19,11 +19,11 @@ int
- foo (int x)
- {
-   if (x < 10)
--    [[clang::musttail]] return foo2 (x, 29);
-+    [[gnu::musttail]] return foo2 (x, 29);
-   if (x < 100)
-     {
-       int k = foo (x + 1);
--      [[clang::musttail]] return k;	/* { dg-error "cannot tail-call: " } */
-+      [[gnu::musttail]] return k;	/* { dg-error "cannot tail-call: " } */
-     }
-   return x;
- }
-diff --git a/gcc/testsuite/g++.dg/musttail14.C b/gcc/testsuite/g++.dg/musttail14.C
-index 810b45546d61..e4764a3bc03b 100644
---- a/gcc/testsuite/g++.dg/musttail14.C
-+++ b/gcc/testsuite/g++.dg/musttail14.C
-@@ -58,8 +58,8 @@ garply (int x)
-     case 3:
-       __attribute__(()) [[gnu::musttail]] __attribute__(()) [[]] __attribute__(()) return qux (45);
-     case 4:
--      [[]] __attribute__(()) [[clang::musttail]] __attribute__(()) [[]] return corge (46);
-+      [[]] __attribute__(()) [[gnu::musttail]] __attribute__(()) [[]] return corge (46);
-     default:
--      __attribute__(()) [[clang::musttail]] __attribute__(()) [[]] __attribute__(()) return freddy (47);
-+      __attribute__(()) [[gnu::musttail]] __attribute__(()) [[]] __attribute__(()) return freddy (47);
-     }
- }
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index c3b9934..5543b1c 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,5 @@
 48	????
 
-	+ 77_all_PR119376-Disable-clang-musttail.patch
 	+ 78_all_PR118615.patch
 	+ 79_all_PR117811-arm-neon-shift.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-21 16:23 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-21 16:23 UTC (permalink / raw
  To: gentoo-commits
commit:     346097d6dbc0fe0fc42cacf029a18204f0a54415
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 21 16:23:35 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar 21 16:23:35 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=346097d6
15.0.0: update 78_all_PR118615.patch (cosmetic)
This just adds the changelog etc.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/78_all_PR118615.patch | 97 ++++++++++++++++++++++++++++++++++++-
 1 file changed, 96 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/78_all_PR118615.patch b/15.0.0/gentoo/78_all_PR118615.patch
index 9ae8200..bea0c22 100644
--- a/15.0.0/gentoo/78_all_PR118615.patch
+++ b/15.0.0/gentoo/78_all_PR118615.patch
@@ -1,3 +1,94 @@
+https://inbox.sourceware.org/gcc-patches/Z91i4oSOe2t9Wsu5@tucnak/
+
+Date: Fri, 21 Mar 2025 14:00:18 +0100
+From: Jakub Jelinek <jakub@redhat.com>
+To: Vladimir Makarov <vmakarov@redhat.com>, Jeff Law <jeffreyalaw@gmail.com>,
+        Richard Sandiford <richard.sandiford@arm.com>
+Cc: gcc-patches@gcc.gnu.org, Surya Kumari Jangala <jskumari@linux.ibm.com>,
+        Peter Bergner <bergner@linux.ibm.com>
+Subject: [PATCH] lra, v2: emit caller-save register spills before call insn
+ [PR116028]
+Message-ID: <Z91i4oSOe2t9Wsu5@tucnak>
+Reply-To: Jakub Jelinek <jakub@redhat.com>
+MIME-Version: 1.0
+X-Scanned-By: MIMEDefang 3.0 on 10.30.177.12
+X-Mimecast-Spam-Score: 0
+X-Mimecast-MFC-PROC-ID: _tXP__7Gkm9pvYzp53m4LpOJ23nLH9dr5dUlzvuS5ts_1742562026
+X-Mimecast-Originator: redhat.com
+Content-Type: text/plain; charset=us-ascii
+Content-Disposition: inline
+X-Spam-Status: No, score=-13.6 required=5.0 tests=BAYES_00,DKIM_INVALID,DKIM_SIGNED,KAM_DMARC_QUARANTINE,KAM_DMARC_STATUS,KAM_SHORT,RCVD_IN_DNSWL_NONE,RCVD_IN_HOSTKARMA_W,RCVD_IN_MSPIKE_H5,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE,SPF_NONE,TXREP autolearn=no autolearn_force=no version=3.4.6
+X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on server2.sourceware.org
+List-Id: <gcc-patches.gcc.gnu.org>
+
+Hi!
+
+Here is an updated version of Surya's PR116028 fix from August, which got
+reverted because it caused bootstrap failures on aarch64, later on bootstrap
+comparison errors there as well and problems on other targets as well.
+
+The changes compared to the
+https://gcc.gnu.org/pipermail/gcc-patches/2024-August/658973.html
+version are:
+1) the reason for aarch64 miscompilations and later on bootstrap comparison
+   issues as can be seen on the pr118615.c testcase in the patch was that
+   when curr_insn is a JUMP_INSN or some cases of CALL_INSNs,
+   split_if_necessary is called with before_p true and if it is successful,
+   the code set use_insn = PREV_INSN (curr_insn); instead of use_insn =
+   curr_insn; and that use_insn is then what is passed to
+   add_next_usage_insn; now, if the patch decides to emit the save
+   instruction(s) before the first call after curr_insn in the ebb rather
+   than before the JUMP_INSN/CALL_INSN, PREV_INSN (curr_insn) is some random
+   insn before it, not anything related to the split_reg actions.
+   If it is e.g. a DEBUG_INSN in one case vs. some unrelated other insn
+   otherwise, that can affect further split_reg within the same function
+2) as suggested by Surya in PR118615, it makes no sense to try to change
+   behavior if the first call after curr_insn is in the same bb as curr_insn
+3) split_reg is actually called sometimes from within inherit_in_ebb but
+   sometimes from elsewhere; trying to use whatever last call to
+   inherit_in_ebb saw last is a sure way to run into wrong-code issues,
+   so instead of clearing the rtx var at the start of inherit_in_ebb it is
+   now cleared at the end of it
+4) calling the var latest_call_insn was weird, inherit_in_ebb walks the ebb
+   backwards, so what the var contains is the first call insn within the
+   ebb (after curr_insn)
+5) the patch was using
+   lra_process_new_insns (PREV_INSN (latest_call_insn), NULL, save,
+                          "Add save<-reg");
+   to emit the save insn before latest_call_insn.  That feels quite weird
+   given that latest_call_insn has explicit support for adding stuff
+   before some insn or after some insn, adding something before some
+   insn doesn't really need to be done as addition after PREV_INSN
+6) some formatting nits + new testcase + removal of xfail even on arm32
+
+Bootstrapped/regtested on x86_64-linux/i686-linux (my usual
+--enable-checking=yes,rtl,extra builds), aarch64-linux (normal default
+bootstrap) and our distro scratch build
+({x86_64,i686,aarch64,powerpc64le,s390x}-linux --enable-checking=release
+LTO profiledbootstrap/regtest), I think Sam James tested on 32-bit arm
+too.
+On aarch64-linux this results in
+-FAIL: gcc.dg/pr10474.c scan-rtl-dump pro_and_epilogue "Performing shrink-wrapping"
+
+I admit I don't know the code well nor understood everything it is doing.
+
+I have some concerns:
+1) I wonder if there is a guarantee that first_call_insn if non-NULL will be
+   always in between curr_insn and usage_insn when call_save_p; I'd hope
+   yes because if usage_insn is before first_call_insn in the ebb,
+   presumably it wouldn't need to find call save regs because the range
+   wouldn't cross any calls
+2) I wonder whether it wouldn't be better instead of inserting the saves
+   before first_call_insn insert it at the start of the bb containing that
+   call (after labels of course); emitting it right before a call could
+   mislead code looking for argument slot initialization of the call
+3) even when avoiding the use_insn = PREV_INSN (curr_insn);, I wonder
+   if it is ok to use use_insn equal to curr_insn rather than the insns
+   far later where we actually inserted it, but primarily because I don't
+   understand the code much; I think for the !before_p case it is doing
+   similar thing  on a shorter distance, the saves were emitted after
+   curr_insn and we record it on curr_insn
+
 2025-03-21  Surya Kumari Jangala  <jskumari@linux.ibm.com>
 	    Jakub Jelinek  <jakub@redhat.com>
 
@@ -26,7 +117,7 @@
 +   or NULL outside of that function.  */
 +static rtx_insn *first_call_insn;
  
- 
+ \f
  
 @@ -6373,12 +6376,26 @@ split_reg (bool before_p, int original_r
    lra_process_new_insns (as_a <rtx_insn *> (usage_insn),
@@ -147,3 +238,7 @@
 +    }
 +  baz (&n);
 +}
+
+	Jakub
+
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-21 17:21 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-21 17:21 UTC (permalink / raw
  To: gentoo-commits
commit:     deff508dad5c6dc413e6d7e81ac1c3f53c6ecace
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 21 17:20:45 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar 21 17:20:45 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=deff508d
15.0.0: update neon miscompilation patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/79_all_PR117811-arm-neon-shift.patch | 172 ++++++++++++++-------
 1 file changed, 119 insertions(+), 53 deletions(-)
diff --git a/15.0.0/gentoo/79_all_PR117811-arm-neon-shift.patch b/15.0.0/gentoo/79_all_PR117811-arm-neon-shift.patch
index f2bb73a..5a78653 100644
--- a/15.0.0/gentoo/79_all_PR117811-arm-neon-shift.patch
+++ b/15.0.0/gentoo/79_all_PR117811-arm-neon-shift.patch
@@ -1,77 +1,146 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=117811#c20
+https://inbox.sourceware.org/gcc-patches/20250321094756.1044263-1-rearnsha@arm.com/
 
-From 5256e5419d07f7313fe661901b9a4821b3d47764 Mon Sep 17 00:00:00 2001
-From: Andrew Pinski <quic_apinski@quicinc.com>
-Date: Wed, 19 Mar 2025 16:02:12 -0700
-Subject: [PATCH] Fix expand_binop_directly in some cases [PR117811]
+From db60414d7b3f596214547fc9a7c74fcb38248527 Mon Sep 17 00:00:00 2001
+Message-ID: <db60414d7b3f596214547fc9a7c74fcb38248527.1742577601.git.sam@gentoo.org>
+From: Richard Earnshaw <rearnsha@arm.com>
+Date: Fri, 21 Mar 2025 09:47:56 +0000
+Subject: [PATCH] opcodes: fix wrong code in expand_binop_directly [PR117811]
 
-The problem here is that when dealing with adding the equal note,
-we decide to call expand_binop directly but before we do that we
-call delete_insns_since with the last argument. The problem is that
-deletes too much and falls over. So instead we need to delete only
-up to what was done at the point of the call to expand_binop_directly
+If expand_binop_directly fails to add a REG_EQUAL note it tries to
+unwind and restart.  But it can unwind too far if expand_binop changed
+some of the operands before calling it.  We don't need to unwind that
+far anyway since we should end up taking exactly the same route next
+time, just without a target rtx.
 
-Bootstrapped and tested on x86_64-linux-gnu.  Also Christophe Lyon tested
-it on arm-linux-gnueabihf.
-
-	PR middle-end/117811
+To fix this we remove LAST from the argument list and let the callers
+(all in expand_binop) do their own unwinding if the call fails.
+Instead we unwind just as far as the entry to expand_binop_directly
+and recurse within this function instead of all the way back up.
 
 gcc/ChangeLog:
 
-	* optabs.cc (expand_binop_directly): Delete only what was done
-	since the entry before calling expand_binop.
-
-gcc/testsuite/ChangeLog:
+	PR middle-end/117811
+	* optabs.cc (expand_binop_directly): Remove LAST as an argument,
+	instead record the last insn on entry.  Only delete insns if
+	we need to restart and restart by calling ourself, not expand_binop.
+	(expand_binop): Update callers to expand_binop_directly.  If it
+	fails to expand the operation, delete back to LAST.
 
-	* c-c++-common/torture/pr117811-1.c: New test.
+gcc/testsuite:
 
-Signed-off-by: Andrew Pinski <quic_apinski@quicinc.com>
+PR middle-end/117811
+	* gcc.dg/torture/pr117811.c: New test.
 ---
- gcc/optabs.cc                                 |  3 +-
- .../c-c++-common/torture/pr117811-1.c         | 32 +++++++++++++++++++
- 2 files changed, 34 insertions(+), 1 deletion(-)
- create mode 100644 gcc/testsuite/c-c++-common/torture/pr117811-1.c
+ gcc/optabs.cc                           | 24 +++++++++++-----------
+ gcc/testsuite/gcc.dg/torture/pr117811.c | 27 +++++++++++++++++++++++++
+ 2 files changed, 39 insertions(+), 12 deletions(-)
+ create mode 100644 gcc/testsuite/gcc.dg/torture/pr117811.c
 
 diff --git a/gcc/optabs.cc b/gcc/optabs.cc
-index 36f2e6af8b5..366df985147 100644
+index 36f2e6af8b5c..0a14b1eef8a5 100644
 --- a/gcc/optabs.cc
 +++ b/gcc/optabs.cc
-@@ -1380,6 +1380,7 @@ expand_binop_directly (enum insn_code icode, machine_mode mode, optab binoptab,
+@@ -1369,8 +1369,7 @@ avoid_expensive_constant (machine_mode mode, optab binoptab,
+ static rtx
+ expand_binop_directly (enum insn_code icode, machine_mode mode, optab binoptab,
+ 		       rtx op0, rtx op1,
+-		       rtx target, int unsignedp, enum optab_methods methods,
+-		       rtx_insn *last)
++		       rtx target, int unsignedp, enum optab_methods methods)
+ {
+   machine_mode xmode0 = insn_data[(int) icode].operand[1].mode;
+   machine_mode xmode1 = insn_data[(int) icode].operand[2].mode;
+@@ -1380,6 +1379,7 @@ expand_binop_directly (enum insn_code icode, machine_mode mode, optab binoptab,
    rtx_insn *pat;
    rtx xop0 = op0, xop1 = op1;
    bool canonicalize_op1 = false;
-+  rtx_insn *entry_last = get_last_insn ();
++  rtx_insn *last = get_last_insn ();
  
    /* If it is a commutative operator and the modes would match
       if we would swap the operands, we can save the conversions.  */
-@@ -1466,7 +1467,7 @@ expand_binop_directly (enum insn_code icode, machine_mode mode, optab binoptab,
- 			       optab_to_code (binoptab),
+@@ -1444,10 +1444,7 @@ expand_binop_directly (enum insn_code icode, machine_mode mode, optab binoptab,
+       tmp_mode = insn_data[(int) icode].operand[0].mode;
+       if (VECTOR_MODE_P (mode)
+ 	  && maybe_ne (GET_MODE_NUNITS (tmp_mode), 2 * GET_MODE_NUNITS (mode)))
+-	{
+-	  delete_insns_since (last);
+-	  return NULL_RTX;
+-	}
++	return NULL_RTX;
+     }
+   else
+     tmp_mode = mode;
+@@ -1467,14 +1464,14 @@ expand_binop_directly (enum insn_code icode, machine_mode mode, optab binoptab,
  			       ops[1].value, ops[2].value, mode0))
  	{
--	  delete_insns_since (last);
-+	  delete_insns_since (entry_last);
- 	  return expand_binop (mode, binoptab, op0, op1, NULL_RTX,
- 			       unsignedp, methods);
+ 	  delete_insns_since (last);
+-	  return expand_binop (mode, binoptab, op0, op1, NULL_RTX,
+-			       unsignedp, methods);
++	  return expand_binop_directly (icode, mode, binoptab, op0, op1,
++					NULL_RTX, unsignedp, methods);
+ 	}
+ 
+       emit_insn (pat);
+       return ops[0].value;
+     }
+-  delete_insns_since (last);
++
+   return NULL_RTX;
+ }
+ 
+@@ -1543,9 +1540,10 @@ expand_binop (machine_mode mode, optab binoptab, rtx op0, rtx op1,
+       if (icode != CODE_FOR_nothing)
+ 	{
+ 	  temp = expand_binop_directly (icode, mode, binoptab, op0, op1,
+-					target, unsignedp, methods, last);
++					target, unsignedp, methods);
+ 	  if (temp)
+ 	    return temp;
++	  delete_insns_since (last);
+ 	}
+     }
+ 
+@@ -1571,9 +1569,10 @@ expand_binop (machine_mode mode, optab binoptab, rtx op0, rtx op1,
+ 			       NULL_RTX, unsignedp, OPTAB_DIRECT);
+ 
+       temp = expand_binop_directly (icode, int_mode, otheroptab, op0, newop1,
+-				    target, unsignedp, methods, last);
++				    target, unsignedp, methods);
+       if (temp)
+ 	return temp;
++      delete_insns_since (last);
+     }
+ 
+   /* If this is a multiply, see if we can do a widening operation that
+@@ -1637,9 +1636,10 @@ expand_binop (machine_mode mode, optab binoptab, rtx op0, rtx op1,
+ 	  if (vop1)
+ 	    {
+ 	      temp = expand_binop_directly (icode, mode, otheroptab, op0, vop1,
+-					    target, unsignedp, methods, last);
++					    target, unsignedp, methods);
+ 	      if (temp)
+ 		return temp;
++	      delete_insns_since (last);
+ 	    }
  	}
-diff --git a/gcc/testsuite/c-c++-common/torture/pr117811-1.c b/gcc/testsuite/c-c++-common/torture/pr117811-1.c
+     }
+diff --git a/gcc/testsuite/gcc.dg/torture/pr117811.c b/gcc/testsuite/gcc.dg/torture/pr117811.c
 new file mode 100644
-index 00000000000..a0558cbd0ae
+index 000000000000..13d7e1347807
 --- /dev/null
-+++ b/gcc/testsuite/c-c++-common/torture/pr117811-1.c
-@@ -0,0 +1,32 @@
++++ b/gcc/testsuite/gcc.dg/torture/pr117811.c
+@@ -0,0 +1,27 @@
 +/* { dg-do run } */
 +
-+/* PR middle-end/117811 */
-+/* Tests that right shift on vectors work. */
++#include <string.h>
 +
-+typedef int v4 __attribute__((vector_size(4*sizeof(int))));
++typedef int v4 __attribute__((vector_size (4 * sizeof (int))));
 +
-+void buggy_shift( v4 *vec, int shift ) __attribute__((noipa));
-+void buggy_shift( v4 *vec, int shift )
++void __attribute__((noclone,noinline)) do_shift (v4 *vec, int shift)
 +{
 +  v4 t = *vec;
 +
-+  if ( shift > 0 )
++  if (shift > 0)
 +  {
 +    t = t >> shift;
 +  }
@@ -79,18 +148,15 @@ index 00000000000..a0558cbd0ae
 +  *vec = t;
 +}
 +
-+int main()
++int main ()
 +{
-+  v4 v = {0x0<<4, 0x1<<4, 2<<4, 3<<4};
-+  v4 r = {0x0, 0x1, 2, 3};
-+  int shift = 4;
-+  buggy_shift(&v, shift);
-+  for(int i = 0; i < 4; i++)
-+    if (v[i] != r[i])
-+      __builtin_abort();
++  v4 vec =  {0x1000000, 0x2000, 0x300, 0x40};
++  v4 vec2 = {0x100000,  0x200,  0x30,  0x4};
++  do_shift (&vec, 4);
++  if (memcmp (&vec, &vec2, sizeof (v4)) != 0)
++    __builtin_abort ();
 +  return 0;
 +}
-+
 -- 
-2.43.0
+2.49.0
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-21 19:31 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-21 19:31 UTC (permalink / raw
  To: gentoo-commits
commit:     5c804b8430a3758731aa1ea866b86b4390d0bb57
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 21 19:31:39 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar 21 19:31:39 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=5c804b84
15.0.0: drop upstream LRA patch
Just merged.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/78_all_PR118615.patch | 244 ------------------------------------
 15.0.0/gentoo/README.history        |   1 -
 2 files changed, 245 deletions(-)
diff --git a/15.0.0/gentoo/78_all_PR118615.patch b/15.0.0/gentoo/78_all_PR118615.patch
deleted file mode 100644
index bea0c22..0000000
--- a/15.0.0/gentoo/78_all_PR118615.patch
+++ /dev/null
@@ -1,244 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/Z91i4oSOe2t9Wsu5@tucnak/
-
-Date: Fri, 21 Mar 2025 14:00:18 +0100
-From: Jakub Jelinek <jakub@redhat.com>
-To: Vladimir Makarov <vmakarov@redhat.com>, Jeff Law <jeffreyalaw@gmail.com>,
-        Richard Sandiford <richard.sandiford@arm.com>
-Cc: gcc-patches@gcc.gnu.org, Surya Kumari Jangala <jskumari@linux.ibm.com>,
-        Peter Bergner <bergner@linux.ibm.com>
-Subject: [PATCH] lra, v2: emit caller-save register spills before call insn
- [PR116028]
-Message-ID: <Z91i4oSOe2t9Wsu5@tucnak>
-Reply-To: Jakub Jelinek <jakub@redhat.com>
-MIME-Version: 1.0
-X-Scanned-By: MIMEDefang 3.0 on 10.30.177.12
-X-Mimecast-Spam-Score: 0
-X-Mimecast-MFC-PROC-ID: _tXP__7Gkm9pvYzp53m4LpOJ23nLH9dr5dUlzvuS5ts_1742562026
-X-Mimecast-Originator: redhat.com
-Content-Type: text/plain; charset=us-ascii
-Content-Disposition: inline
-X-Spam-Status: No, score=-13.6 required=5.0 tests=BAYES_00,DKIM_INVALID,DKIM_SIGNED,KAM_DMARC_QUARANTINE,KAM_DMARC_STATUS,KAM_SHORT,RCVD_IN_DNSWL_NONE,RCVD_IN_HOSTKARMA_W,RCVD_IN_MSPIKE_H5,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE,SPF_NONE,TXREP autolearn=no autolearn_force=no version=3.4.6
-X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on server2.sourceware.org
-List-Id: <gcc-patches.gcc.gnu.org>
-
-Hi!
-
-Here is an updated version of Surya's PR116028 fix from August, which got
-reverted because it caused bootstrap failures on aarch64, later on bootstrap
-comparison errors there as well and problems on other targets as well.
-
-The changes compared to the
-https://gcc.gnu.org/pipermail/gcc-patches/2024-August/658973.html
-version are:
-1) the reason for aarch64 miscompilations and later on bootstrap comparison
-   issues as can be seen on the pr118615.c testcase in the patch was that
-   when curr_insn is a JUMP_INSN or some cases of CALL_INSNs,
-   split_if_necessary is called with before_p true and if it is successful,
-   the code set use_insn = PREV_INSN (curr_insn); instead of use_insn =
-   curr_insn; and that use_insn is then what is passed to
-   add_next_usage_insn; now, if the patch decides to emit the save
-   instruction(s) before the first call after curr_insn in the ebb rather
-   than before the JUMP_INSN/CALL_INSN, PREV_INSN (curr_insn) is some random
-   insn before it, not anything related to the split_reg actions.
-   If it is e.g. a DEBUG_INSN in one case vs. some unrelated other insn
-   otherwise, that can affect further split_reg within the same function
-2) as suggested by Surya in PR118615, it makes no sense to try to change
-   behavior if the first call after curr_insn is in the same bb as curr_insn
-3) split_reg is actually called sometimes from within inherit_in_ebb but
-   sometimes from elsewhere; trying to use whatever last call to
-   inherit_in_ebb saw last is a sure way to run into wrong-code issues,
-   so instead of clearing the rtx var at the start of inherit_in_ebb it is
-   now cleared at the end of it
-4) calling the var latest_call_insn was weird, inherit_in_ebb walks the ebb
-   backwards, so what the var contains is the first call insn within the
-   ebb (after curr_insn)
-5) the patch was using
-   lra_process_new_insns (PREV_INSN (latest_call_insn), NULL, save,
-                          "Add save<-reg");
-   to emit the save insn before latest_call_insn.  That feels quite weird
-   given that latest_call_insn has explicit support for adding stuff
-   before some insn or after some insn, adding something before some
-   insn doesn't really need to be done as addition after PREV_INSN
-6) some formatting nits + new testcase + removal of xfail even on arm32
-
-Bootstrapped/regtested on x86_64-linux/i686-linux (my usual
---enable-checking=yes,rtl,extra builds), aarch64-linux (normal default
-bootstrap) and our distro scratch build
-({x86_64,i686,aarch64,powerpc64le,s390x}-linux --enable-checking=release
-LTO profiledbootstrap/regtest), I think Sam James tested on 32-bit arm
-too.
-On aarch64-linux this results in
--FAIL: gcc.dg/pr10474.c scan-rtl-dump pro_and_epilogue "Performing shrink-wrapping"
-
-I admit I don't know the code well nor understood everything it is doing.
-
-I have some concerns:
-1) I wonder if there is a guarantee that first_call_insn if non-NULL will be
-   always in between curr_insn and usage_insn when call_save_p; I'd hope
-   yes because if usage_insn is before first_call_insn in the ebb,
-   presumably it wouldn't need to find call save regs because the range
-   wouldn't cross any calls
-2) I wonder whether it wouldn't be better instead of inserting the saves
-   before first_call_insn insert it at the start of the bb containing that
-   call (after labels of course); emitting it right before a call could
-   mislead code looking for argument slot initialization of the call
-3) even when avoiding the use_insn = PREV_INSN (curr_insn);, I wonder
-   if it is ok to use use_insn equal to curr_insn rather than the insns
-   far later where we actually inserted it, but primarily because I don't
-   understand the code much; I think for the !before_p case it is doing
-   similar thing  on a shorter distance, the saves were emitted after
-   curr_insn and we record it on curr_insn
-
-2025-03-21  Surya Kumari Jangala  <jskumari@linux.ibm.com>
-	    Jakub Jelinek  <jakub@redhat.com>
-
-	PR rtl-optimization/116028
-	PR rtl-optimization/118615
-	* lra-constraints.cc (first_call_insn): New variable.
-	(split_reg): Spill register before first_call_insn if call_save_p
-	and the call is in a different bb in the ebb.
-	(split_if_necessary): Formatting fix.
-	(inherit_in_ebb): Set first_call_insn when handling a CALL_INSN.
-	For successful split_if_necessary with before_p, only change
-	use_insn if it emitted any new instructions before curr_insn.
-	Clear first_call_insn before returning.
-	
-	* gcc.dg/ira-shrinkwrap-prep-1.c: Remove xfail for powerpc.
-	* gcc.dg/pr10474.c: Remove xfail for powerpc and arm.
-	* gcc.dg/pr118615.c: New test.
-
---- a/gcc/lra-constraints.cc	2025-03-19 19:20:41.644440691 +0100
-+++ b/gcc/lra-constraints.cc	2025-03-20 18:40:04.188299643 +0100
-@@ -152,6 +152,9 @@ static machine_mode curr_operand_mode[MA
-    (e.g. constant) and whose subreg is given operand of the current
-    insn.  VOIDmode in all other cases.  */
- static machine_mode original_subreg_reg_mode[MAX_RECOG_OPERANDS];
-+/* The first call insn after curr_insn within the EBB during inherit_in_ebb
-+   or NULL outside of that function.  */
-+static rtx_insn *first_call_insn;
- 
- \f
- 
-@@ -6373,12 +6376,26 @@ split_reg (bool before_p, int original_r
-   lra_process_new_insns (as_a <rtx_insn *> (usage_insn),
- 			 after_p ? NULL : restore,
- 			 after_p ? restore : NULL,
--			 call_save_p
--			 ?  "Add reg<-save" : "Add reg<-split");
--  lra_process_new_insns (insn, before_p ? save : NULL,
--			 before_p ? NULL : save,
--			 call_save_p
--			 ?  "Add save<-reg" : "Add split<-reg");
-+			 call_save_p ? "Add reg<-save" : "Add reg<-split");
-+  if (call_save_p
-+      && first_call_insn != NULL
-+      && BLOCK_FOR_INSN (first_call_insn) != BLOCK_FOR_INSN (insn))
-+    /* PR116028: If original_regno is a pseudo that has been assigned a
-+       call-save hard register, then emit the spill insn before the call
-+       insn 'first_call_insn' instead of adjacent to 'insn'.  If 'insn'
-+       and 'first_call_insn' belong to the same EBB but to two separate
-+       BBs, and if 'insn' is present in the entry BB, then generating the
-+       spill insn in the entry BB can prevent shrink wrap from happening.
-+       This is because the spill insn references the stack pointer and
-+       hence the prolog gets generated in the entry BB itself.  It is
-+       also more efficient to generate the spill before
-+       'first_call_insn' as the spill now occurs only in the path
-+       containing the call.  */
-+    lra_process_new_insns (first_call_insn, save, NULL, "Add save<-reg");
-+  else
-+    lra_process_new_insns (insn, before_p ? save : NULL,
-+			   before_p ? NULL : save,
-+			   call_save_p ? "Add save<-reg" : "Add split<-reg");
-   if (nregs > 1 || original_regno < FIRST_PSEUDO_REGISTER)
-     /* If we are trying to split multi-register.  We should check
-        conflicts on the next assignment sub-pass.  IRA can allocate on
-@@ -6484,7 +6501,7 @@ split_if_necessary (int regno, machine_m
- 		&& (INSN_UID (XEXP (next_usage_insns, 0)) < max_uid)))
- 	&& need_for_split_p (potential_reload_hard_regs, regno + i)
- 	&& split_reg (before_p, regno + i, insn, next_usage_insns, NULL))
--    res = true;
-+      res = true;
-   return res;
- }
- 
-@@ -7074,6 +7092,7 @@ inherit_in_ebb (rtx_insn *head, rtx_insn
- 	      last_call_for_abi[callee_abi.id ()] = calls_num;
- 	      full_and_partial_call_clobbers
- 		|= callee_abi.full_and_partial_reg_clobbers ();
-+	      first_call_insn = curr_insn;
- 	      if ((cheap = find_reg_note (curr_insn,
- 					  REG_RETURNED, NULL_RTX)) != NULL_RTX
- 		  && ((cheap = XEXP (cheap, 0)), true)
-@@ -7142,6 +7161,7 @@ inherit_in_ebb (rtx_insn *head, rtx_insn
- 		    {
- 		      bool before_p;
- 		      rtx_insn *use_insn = curr_insn;
-+		      rtx_insn *prev_insn = PREV_INSN (curr_insn);
- 
- 		      before_p = (JUMP_P (curr_insn)
- 				  || (CALL_P (curr_insn) && reg->type == OP_IN));
-@@ -7156,7 +7176,7 @@ inherit_in_ebb (rtx_insn *head, rtx_insn
- 			  change_p = true;
- 			  /* Invalidate. */
- 			  usage_insns[src_regno].check = 0;
--			  if (before_p)
-+			  if (before_p && PREV_INSN (curr_insn) != prev_insn)
- 			    use_insn = PREV_INSN (curr_insn);
- 			}
- 		      if (NONDEBUG_INSN_P (curr_insn))
-@@ -7278,6 +7298,7 @@ inherit_in_ebb (rtx_insn *head, rtx_insn
- 	    }
- 	}
-     }
-+  first_call_insn = NULL;
-   return change_p;
- }
- 
---- a/gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c	2024-07-01 11:28:23.278230620 +0200
-+++ b/gcc/testsuite/gcc.dg/ira-shrinkwrap-prep-1.c	2025-03-20 19:50:49.369486995 +0100
-@@ -26,4 +26,4 @@ bar (long a)
- 
- /* { dg-final { scan-rtl-dump "Will split live ranges of parameters" "ira" } } */
- /* { dg-final { scan-rtl-dump "Split live-range of register" "ira" { xfail { ! aarch64*-*-* } } } } */
--/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue" { xfail powerpc*-*-* } } } */
-+/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue" } } */
---- a/gcc/testsuite/gcc.dg/pr10474.c	2025-03-20 19:50:49.379486857 +0100
-+++ b/gcc/testsuite/gcc.dg/pr10474.c	2025-03-21 09:33:23.808051052 +0100
-@@ -12,5 +12,4 @@ void f(int *i)
- 	}
- }
- 
--/* XFAIL due to PR70681.  */ 
--/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue"  { xfail arm*-*-* powerpc*-*-* } } } */
-+/* { dg-final { scan-rtl-dump "Performing shrink-wrapping" "pro_and_epilogue" } } */
---- a/gcc/testsuite/gcc.dg/pr118615.c	2025-03-21 09:44:26.502876412 +0100
-+++ b/gcc/testsuite/gcc.dg/pr118615.c	2025-03-21 09:45:22.447104189 +0100
-@@ -0,0 +1,24 @@
-+/* PR rtl-optimization/118615 */
-+/* { dg-do compile { target scheduling } } */
-+/* { dg-options "-O2 -fcompare-debug -fschedule-insns" } */
-+
-+void foo (void);
-+void bar (int);
-+void baz (int *);
-+int j;
-+
-+void
-+qux (int k, int *m)
-+{
-+  int n;
-+  if (k)
-+    {
-+      foo ();
-+      if (m)
-+	{
-+	  bar (j);
-+	  baz (m);
-+	}
-+    }
-+  baz (&n);
-+}
-
-	Jakub
-
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 5543b1c..f301994 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,5 @@
 48	????
 
-	+ 78_all_PR118615.patch
 	+ 79_all_PR117811-arm-neon-shift.patch
 
 47	16 March 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-24  0:35 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-24  0:35 UTC (permalink / raw
  To: gentoo-commits
commit:     73ee974284a31dc4994e9039ea9584fb1cf7c7f9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 24 00:34:53 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Mar 24 00:35:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=73ee9742
15.0.0: cut patchset 48
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index f301994..45773fe 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-48	????
+48	24 March 2025
 
 	+ 79_all_PR117811-arm-neon-shift.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-25  1:27 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-25  1:27 UTC (permalink / raw
  To: gentoo-commits
commit:     b2c0fd1b027e6effa08eb2657dc54ce49829a7f0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 25 01:27:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Mar 25 01:27:27 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b2c0fd1b
15.0.0: add fix for sqlite/e2fsprogs miscompilation
Bug: https://gcc.gnu.org/PR119428
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/80_all_PR119428.patch | 56 +++++++++++++++++++++++++++++++++++++
 15.0.0/gentoo/README.history        |  4 +++
 2 files changed, 60 insertions(+)
diff --git a/15.0.0/gentoo/80_all_PR119428.patch b/15.0.0/gentoo/80_all_PR119428.patch
new file mode 100644
index 0000000..45b1bf5
--- /dev/null
+++ b/15.0.0/gentoo/80_all_PR119428.patch
@@ -0,0 +1,56 @@
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119428#c10
+
+2025-03-24  Jakub Jelinek  <jakub@redhat.com>
+
+	PR target/96226
+	PR target/119428
+	* config/i386/i386.md (splitter after *<rotate_insn><mode>3_mask,
+	splitter after *<rotate_insn><mode>3_mask_1): Revert 2020-12-05
+	changes.
+
+	* gcc.c-torture/execute/pr119428.c: New test.
+
+--- a/gcc/config/i386/i386.md	2025-03-24 11:29:12.271793423 +0100
++++ b/gcc/config/i386/i386.md	2025-03-24 11:32:14.139305881 +0100
+@@ -18168,7 +18168,8 @@ (define_split
+  [(set (match_dup 4) (match_dup 1))
+   (set (match_dup 0)
+        (any_rotate:SWI (match_dup 4)
+-		       (subreg:QI (match_dup 2) 0)))]
++		       (subreg:QI
++			 (and:SI (match_dup 2) (match_dup 3)) 0)))]
+  "operands[4] = gen_reg_rtx (<MODE>mode);")
+ 
+ (define_insn_and_split "*<insn><mode>3_mask_1"
+@@ -18202,7 +18203,8 @@ (define_split
+   == GET_MODE_BITSIZE (<MODE>mode) - 1"
+  [(set (match_dup 4) (match_dup 1))
+   (set (match_dup 0)
+-       (any_rotate:SWI (match_dup 4) (match_dup 2)))]
++       (any_rotate:SWI (match_dup 4)
++		       (and:QI (match_dup 2) (match_dup 3))))]
+  "operands[4] = gen_reg_rtx (<MODE>mode);")
+ 
+ (define_insn_and_split "*<insn><mode>3_add"
+--- a/gcc/testsuite/gcc.c-torture/execute/pr119428.c	2025-03-24 11:41:31.583658619 +0100
++++ b/gcc/testsuite/gcc.c-torture/execute/pr119428.c	2025-03-24 11:40:37.884395211 +0100
+@@ -0,0 +1,18 @@
++/* PR target/119428 */
++
++__attribute__((noipa)) void
++foo (unsigned int x, unsigned char *y)
++{
++  y += x >> 3;
++  *y &= (unsigned char) ~(1 << (x & 0x07));
++}
++
++int
++main ()
++{
++  unsigned char buf[8];
++  __builtin_memset (buf, 0xff, 8);
++  foo (8, buf);
++  if (buf[1] != 0xfe)
++    __builtin_abort ();
++}
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 45773fe..92b88c3 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+49	????
+
+	+ 80_all_PR119428.patch
+
 48	24 March 2025
 
 	+ 79_all_PR117811-arm-neon-shift.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-25  2:32 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-25  2:32 UTC (permalink / raw
  To: gentoo-commits
commit:     ff1ba90cc398eb99d4e5514e0f0332c2105c5872
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 25 02:32:13 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Mar 25 02:32:13 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ff1ba90c
Revert "15.0.0: drop musttail workaround"
This reverts commit ebea0f72bf6bcc9c53105a689beb6263047b35c8.
More issues.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../77_all_PR119376-Disable-clang-musttail.patch   | 200 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 201 insertions(+)
diff --git a/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch b/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch
new file mode 100644
index 0000000..3af4ab4
--- /dev/null
+++ b/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch
@@ -0,0 +1,200 @@
+https://inbox.sourceware.org/gcc-patches/20250320013102.1336516-1-andi@firstfloor.org/
+
+From 592f60bef27cb60ea6405ca8603449fc4d92e640 Mon Sep 17 00:00:00 2001
+Message-ID: <592f60bef27cb60ea6405ca8603449fc4d92e640.1742435883.git.sam@gentoo.org>
+From: Andi Kleen <ak@gcc.gnu.org>
+Date: Wed, 19 Mar 2025 18:31:02 -0700
+Subject: [PATCH] PR119376: Disable clang musttail
+
+There are multiple reports (see PR 119376) now where semantic differences
+in the gcc musttail implementation break existing programs written for the clang
+variant.
+
+Even though that can be all hopefully fixed eventually,
+for the gcc 15 release it seems safer to disable clang::musttail,
+and only keep gnu::musttail.
+
+That means that programs that use __has_c_attribute to check for
+clang::musttail must opt-in explicitly.
+
+Reported-by: Sam James
+
+gcc/c/ChangeLog:
+
+	PR ipa/119376
+	* c-parser.cc (c_parser_handle_musttail): Drop clang namespace
+	check.
+
+gcc/cp/ChangeLog:
+
+	PR ipa/119376
+	* parser.cc (cp_parser_jump_statement): Drop clang namespace
+	check.
+
+gcc/ChangeLog:
+
+	PR ipa/119376
+	* doc/extend.texi: Drop clang::musttail reference.
+
+gcc/testsuite/ChangeLog:
+
+PR ipa/119376
+	* c-c++-common/musttail23.c: Don't use clang::musttail
+	* c-c++-common/musttail24.c: Dito.
+	* c-c++-common/musttail3.c: Dito.
+	* g++.dg/musttail14.C: Dito.
+---
+ gcc/c/c-parser.cc                       |  5 -----
+ gcc/cp/parser.cc                        |  6 ------
+ gcc/doc/extend.texi                     |  2 +-
+ gcc/testsuite/c-c++-common/musttail23.c | 10 +++++-----
+ gcc/testsuite/c-c++-common/musttail24.c |  6 ------
+ gcc/testsuite/c-c++-common/musttail3.c  |  6 +++---
+ gcc/testsuite/g++.dg/musttail14.C       |  4 ++--
+ 7 files changed, 11 insertions(+), 28 deletions(-)
+
+diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
+index d49d5c58659f..79654448acaa 100644
+--- a/gcc/c/c-parser.cc
++++ b/gcc/c/c-parser.cc
+@@ -7409,11 +7409,6 @@ c_parser_handle_musttail (c_parser *parser, tree std_attrs, attr_state &attr)
+ 	  std_attrs = remove_attribute ("gnu", "musttail", std_attrs);
+ 	  attr.musttail_p = true;
+ 	}
+-      if (lookup_attribute ("clang", "musttail", std_attrs))
+-	{
+-	  std_attrs = remove_attribute ("clang", "musttail", std_attrs);
+-	  attr.musttail_p = true;
+-	}
+     }
+   return std_attrs;
+ }
+diff --git a/gcc/cp/parser.cc b/gcc/cp/parser.cc
+index 2fb1dc5992d4..da7700b55c64 100644
+--- a/gcc/cp/parser.cc
++++ b/gcc/cp/parser.cc
+@@ -15342,12 +15342,6 @@ cp_parser_jump_statement (cp_parser* parser, tree &std_attrs)
+ 		musttail_p = true;
+ 		std_attrs = remove_attribute ("gnu", "musttail", std_attrs);
+ 	      }
+-	    /* Support this for compatibility.  */
+-	    if (lookup_attribute ("clang", "musttail", std_attrs))
+-	      {
+-		musttail_p = true;
+-		std_attrs = remove_attribute ("clang", "musttail", std_attrs);
+-	      }
+ 
+ 	    tree ret_expr = expr;
+ 	    if (ret_expr && TREE_CODE (ret_expr) == TARGET_EXPR)
+diff --git a/gcc/doc/extend.texi b/gcc/doc/extend.texi
+index b919df914648..50f95e968ff9 100644
+--- a/gcc/doc/extend.texi
++++ b/gcc/doc/extend.texi
+@@ -10241,7 +10241,7 @@ have to optimize it to just @code{return 42 + 42;}.
+ @cindex @code{musttail} statement attribute
+ @item musttail
+ 
+-The @code{gnu::musttail} or @code{clang::musttail} standard attribute
++The @code{gnu::musttail} standard attribute
+ or @code{musttail} GNU attribute can be applied to a @code{return} statement
+ with a return-value expression that is a function call.  It asserts that the
+ call must be a tail call that does not allocate extra stack space, so it is
+diff --git a/gcc/testsuite/c-c++-common/musttail23.c b/gcc/testsuite/c-c++-common/musttail23.c
+index d2ba70b03250..1ceab1165129 100644
+--- a/gcc/testsuite/c-c++-common/musttail23.c
++++ b/gcc/testsuite/c-c++-common/musttail23.c
+@@ -19,10 +19,10 @@ foo (int x)
+     [[gnu::musttail (1, "", 3)]] return bar ();		/* { dg-error "'musttail' attribute does not take any arguments" } */
+ 							/* { dg-error "expected" "" { target c } .-1 } */
+   if (x == 3)
+-    [[clang::musttail (1)]] return bar ();		/* { dg-error "'musttail' attribute does not take any arguments" } */
++    [[gnu::musttail (1)]] return bar ();		/* { dg-error "'musttail' attribute does not take any arguments" } */
+ 							/* { dg-error "expected" "" { target c } .-1 } */
+   if (x == 4)
+-    [[clang::musttail (1, "", 3)]] return bar ();	/* { dg-error "'musttail' attribute does not take any arguments" } */
++    [[gnu::musttail (1, "", 3)]] return bar ();	/* { dg-error "'musttail' attribute does not take any arguments" } */
+ 							/* { dg-error "expected" "" { target c } .-1 } */
+   if (x == 5)
+     __attribute__((fallthrough, musttail)) return bar (); /* { dg-warning "attribute 'musttail' mixed with other attributes on 'return' statement" "" { target c } } */
+@@ -32,14 +32,14 @@ foo (int x)
+     [[fallthrough]] [[gnu::musttail]] return bar ();	/* { dg-warning "'fallthrough' attribute ignored" "" { target c } } */
+ 							/* { dg-warning "attributes at the beginning of statement are ignored" "" { target c++ } .-1 } */
+   if (x == 7)
+-    [[clang::musttail, fallthrough]] return bar ();	/* { dg-warning "'fallthrough' attribute ignored" "" { target c } } */
++    [[gnu::musttail, fallthrough]] return bar ();	/* { dg-warning "'fallthrough' attribute ignored" "" { target c } } */
+ 							/* { dg-warning "attributes at the beginning of statement are ignored" "" { target c++ } .-1 } */
+   if (x == 8)
+     __attribute__((musttail, musttail)) return bar ();
+   if (x == 9)
+     [[gnu::musttail, gnu::musttail]] return bar ();
+   if (x == 10)
+-    [[clang::musttail]] [[clang::musttail]] return bar ();
++    [[gnu::musttail]] [[gnu::musttail]] return bar ();
+   if (x == 11)
+-    [[clang::musttail]] [[gnu::musttail]] return bar ();
++    [[gnu::musttail]] [[gnu::musttail]] return bar ();
+ }
+diff --git a/gcc/testsuite/c-c++-common/musttail24.c b/gcc/testsuite/c-c++-common/musttail24.c
+index 10c2d3f188d8..26b8dbfb4c8e 100644
+--- a/gcc/testsuite/c-c++-common/musttail24.c
++++ b/gcc/testsuite/c-c++-common/musttail24.c
+@@ -8,14 +8,8 @@
+ #if !__has_cpp_attribute (gnu::musttail)
+ #error missing gnu::musttail attribute
+ #endif
+-#if !__has_cpp_attribute (clang::musttail)
+-#error missing clang::musttail attribute
+-#endif
+ #else
+ #if !__has_c_attribute (gnu::musttail)
+ #error missing gnu::musttail attribute
+ #endif
+-#if !__has_c_attribute (clang::musttail)
+-#error missing clang::musttail attribute
+-#endif
+ #endif
+diff --git a/gcc/testsuite/c-c++-common/musttail3.c b/gcc/testsuite/c-c++-common/musttail3.c
+index 7499fd6460b4..daedca28852a 100644
+--- a/gcc/testsuite/c-c++-common/musttail3.c
++++ b/gcc/testsuite/c-c++-common/musttail3.c
+@@ -11,7 +11,7 @@ struct str
+ cstruct (int x)
+ {
+   if (x < 10)
+-    [[clang::musttail]] return cstruct (x + 1);
++    [[gnu::musttail]] return cstruct (x + 1);
+   return ((struct str){ x, 0 });
+ }
+ 
+@@ -19,11 +19,11 @@ int
+ foo (int x)
+ {
+   if (x < 10)
+-    [[clang::musttail]] return foo2 (x, 29);
++    [[gnu::musttail]] return foo2 (x, 29);
+   if (x < 100)
+     {
+       int k = foo (x + 1);
+-      [[clang::musttail]] return k;	/* { dg-error "cannot tail-call: " } */
++      [[gnu::musttail]] return k;	/* { dg-error "cannot tail-call: " } */
+     }
+   return x;
+ }
+diff --git a/gcc/testsuite/g++.dg/musttail14.C b/gcc/testsuite/g++.dg/musttail14.C
+index 810b45546d61..e4764a3bc03b 100644
+--- a/gcc/testsuite/g++.dg/musttail14.C
++++ b/gcc/testsuite/g++.dg/musttail14.C
+@@ -58,8 +58,8 @@ garply (int x)
+     case 3:
+       __attribute__(()) [[gnu::musttail]] __attribute__(()) [[]] __attribute__(()) return qux (45);
+     case 4:
+-      [[]] __attribute__(()) [[clang::musttail]] __attribute__(()) [[]] return corge (46);
++      [[]] __attribute__(()) [[gnu::musttail]] __attribute__(()) [[]] return corge (46);
+     default:
+-      __attribute__(()) [[clang::musttail]] __attribute__(()) [[]] __attribute__(()) return freddy (47);
++      __attribute__(()) [[gnu::musttail]] __attribute__(()) [[]] __attribute__(()) return freddy (47);
+     }
+ }
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 92b88c3..2a32843 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 49	????
 
+	+ 77_all_PR119376-Disable-clang-musttail.patch
 	+ 80_all_PR119428.patch
 
 48	24 March 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-25  8:38 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-25  8:38 UTC (permalink / raw
  To: gentoo-commits
commit:     f16f25e451be7aea54515ec7d2dcc68e59407fc7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 25 08:38:22 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Mar 25 08:38:22 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=f16f25e4
15.0.0: drop musttail workaround again
Jakub's committed more fixes.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../77_all_PR119376-Disable-clang-musttail.patch   | 200 ---------------------
 15.0.0/gentoo/README.history                       |   1 -
 2 files changed, 201 deletions(-)
diff --git a/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch b/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch
deleted file mode 100644
index 3af4ab4..0000000
--- a/15.0.0/gentoo/77_all_PR119376-Disable-clang-musttail.patch
+++ /dev/null
@@ -1,200 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/20250320013102.1336516-1-andi@firstfloor.org/
-
-From 592f60bef27cb60ea6405ca8603449fc4d92e640 Mon Sep 17 00:00:00 2001
-Message-ID: <592f60bef27cb60ea6405ca8603449fc4d92e640.1742435883.git.sam@gentoo.org>
-From: Andi Kleen <ak@gcc.gnu.org>
-Date: Wed, 19 Mar 2025 18:31:02 -0700
-Subject: [PATCH] PR119376: Disable clang musttail
-
-There are multiple reports (see PR 119376) now where semantic differences
-in the gcc musttail implementation break existing programs written for the clang
-variant.
-
-Even though that can be all hopefully fixed eventually,
-for the gcc 15 release it seems safer to disable clang::musttail,
-and only keep gnu::musttail.
-
-That means that programs that use __has_c_attribute to check for
-clang::musttail must opt-in explicitly.
-
-Reported-by: Sam James
-
-gcc/c/ChangeLog:
-
-	PR ipa/119376
-	* c-parser.cc (c_parser_handle_musttail): Drop clang namespace
-	check.
-
-gcc/cp/ChangeLog:
-
-	PR ipa/119376
-	* parser.cc (cp_parser_jump_statement): Drop clang namespace
-	check.
-
-gcc/ChangeLog:
-
-	PR ipa/119376
-	* doc/extend.texi: Drop clang::musttail reference.
-
-gcc/testsuite/ChangeLog:
-
-PR ipa/119376
-	* c-c++-common/musttail23.c: Don't use clang::musttail
-	* c-c++-common/musttail24.c: Dito.
-	* c-c++-common/musttail3.c: Dito.
-	* g++.dg/musttail14.C: Dito.
----
- gcc/c/c-parser.cc                       |  5 -----
- gcc/cp/parser.cc                        |  6 ------
- gcc/doc/extend.texi                     |  2 +-
- gcc/testsuite/c-c++-common/musttail23.c | 10 +++++-----
- gcc/testsuite/c-c++-common/musttail24.c |  6 ------
- gcc/testsuite/c-c++-common/musttail3.c  |  6 +++---
- gcc/testsuite/g++.dg/musttail14.C       |  4 ++--
- 7 files changed, 11 insertions(+), 28 deletions(-)
-
-diff --git a/gcc/c/c-parser.cc b/gcc/c/c-parser.cc
-index d49d5c58659f..79654448acaa 100644
---- a/gcc/c/c-parser.cc
-+++ b/gcc/c/c-parser.cc
-@@ -7409,11 +7409,6 @@ c_parser_handle_musttail (c_parser *parser, tree std_attrs, attr_state &attr)
- 	  std_attrs = remove_attribute ("gnu", "musttail", std_attrs);
- 	  attr.musttail_p = true;
- 	}
--      if (lookup_attribute ("clang", "musttail", std_attrs))
--	{
--	  std_attrs = remove_attribute ("clang", "musttail", std_attrs);
--	  attr.musttail_p = true;
--	}
-     }
-   return std_attrs;
- }
-diff --git a/gcc/cp/parser.cc b/gcc/cp/parser.cc
-index 2fb1dc5992d4..da7700b55c64 100644
---- a/gcc/cp/parser.cc
-+++ b/gcc/cp/parser.cc
-@@ -15342,12 +15342,6 @@ cp_parser_jump_statement (cp_parser* parser, tree &std_attrs)
- 		musttail_p = true;
- 		std_attrs = remove_attribute ("gnu", "musttail", std_attrs);
- 	      }
--	    /* Support this for compatibility.  */
--	    if (lookup_attribute ("clang", "musttail", std_attrs))
--	      {
--		musttail_p = true;
--		std_attrs = remove_attribute ("clang", "musttail", std_attrs);
--	      }
- 
- 	    tree ret_expr = expr;
- 	    if (ret_expr && TREE_CODE (ret_expr) == TARGET_EXPR)
-diff --git a/gcc/doc/extend.texi b/gcc/doc/extend.texi
-index b919df914648..50f95e968ff9 100644
---- a/gcc/doc/extend.texi
-+++ b/gcc/doc/extend.texi
-@@ -10241,7 +10241,7 @@ have to optimize it to just @code{return 42 + 42;}.
- @cindex @code{musttail} statement attribute
- @item musttail
- 
--The @code{gnu::musttail} or @code{clang::musttail} standard attribute
-+The @code{gnu::musttail} standard attribute
- or @code{musttail} GNU attribute can be applied to a @code{return} statement
- with a return-value expression that is a function call.  It asserts that the
- call must be a tail call that does not allocate extra stack space, so it is
-diff --git a/gcc/testsuite/c-c++-common/musttail23.c b/gcc/testsuite/c-c++-common/musttail23.c
-index d2ba70b03250..1ceab1165129 100644
---- a/gcc/testsuite/c-c++-common/musttail23.c
-+++ b/gcc/testsuite/c-c++-common/musttail23.c
-@@ -19,10 +19,10 @@ foo (int x)
-     [[gnu::musttail (1, "", 3)]] return bar ();		/* { dg-error "'musttail' attribute does not take any arguments" } */
- 							/* { dg-error "expected" "" { target c } .-1 } */
-   if (x == 3)
--    [[clang::musttail (1)]] return bar ();		/* { dg-error "'musttail' attribute does not take any arguments" } */
-+    [[gnu::musttail (1)]] return bar ();		/* { dg-error "'musttail' attribute does not take any arguments" } */
- 							/* { dg-error "expected" "" { target c } .-1 } */
-   if (x == 4)
--    [[clang::musttail (1, "", 3)]] return bar ();	/* { dg-error "'musttail' attribute does not take any arguments" } */
-+    [[gnu::musttail (1, "", 3)]] return bar ();	/* { dg-error "'musttail' attribute does not take any arguments" } */
- 							/* { dg-error "expected" "" { target c } .-1 } */
-   if (x == 5)
-     __attribute__((fallthrough, musttail)) return bar (); /* { dg-warning "attribute 'musttail' mixed with other attributes on 'return' statement" "" { target c } } */
-@@ -32,14 +32,14 @@ foo (int x)
-     [[fallthrough]] [[gnu::musttail]] return bar ();	/* { dg-warning "'fallthrough' attribute ignored" "" { target c } } */
- 							/* { dg-warning "attributes at the beginning of statement are ignored" "" { target c++ } .-1 } */
-   if (x == 7)
--    [[clang::musttail, fallthrough]] return bar ();	/* { dg-warning "'fallthrough' attribute ignored" "" { target c } } */
-+    [[gnu::musttail, fallthrough]] return bar ();	/* { dg-warning "'fallthrough' attribute ignored" "" { target c } } */
- 							/* { dg-warning "attributes at the beginning of statement are ignored" "" { target c++ } .-1 } */
-   if (x == 8)
-     __attribute__((musttail, musttail)) return bar ();
-   if (x == 9)
-     [[gnu::musttail, gnu::musttail]] return bar ();
-   if (x == 10)
--    [[clang::musttail]] [[clang::musttail]] return bar ();
-+    [[gnu::musttail]] [[gnu::musttail]] return bar ();
-   if (x == 11)
--    [[clang::musttail]] [[gnu::musttail]] return bar ();
-+    [[gnu::musttail]] [[gnu::musttail]] return bar ();
- }
-diff --git a/gcc/testsuite/c-c++-common/musttail24.c b/gcc/testsuite/c-c++-common/musttail24.c
-index 10c2d3f188d8..26b8dbfb4c8e 100644
---- a/gcc/testsuite/c-c++-common/musttail24.c
-+++ b/gcc/testsuite/c-c++-common/musttail24.c
-@@ -8,14 +8,8 @@
- #if !__has_cpp_attribute (gnu::musttail)
- #error missing gnu::musttail attribute
- #endif
--#if !__has_cpp_attribute (clang::musttail)
--#error missing clang::musttail attribute
--#endif
- #else
- #if !__has_c_attribute (gnu::musttail)
- #error missing gnu::musttail attribute
- #endif
--#if !__has_c_attribute (clang::musttail)
--#error missing clang::musttail attribute
--#endif
- #endif
-diff --git a/gcc/testsuite/c-c++-common/musttail3.c b/gcc/testsuite/c-c++-common/musttail3.c
-index 7499fd6460b4..daedca28852a 100644
---- a/gcc/testsuite/c-c++-common/musttail3.c
-+++ b/gcc/testsuite/c-c++-common/musttail3.c
-@@ -11,7 +11,7 @@ struct str
- cstruct (int x)
- {
-   if (x < 10)
--    [[clang::musttail]] return cstruct (x + 1);
-+    [[gnu::musttail]] return cstruct (x + 1);
-   return ((struct str){ x, 0 });
- }
- 
-@@ -19,11 +19,11 @@ int
- foo (int x)
- {
-   if (x < 10)
--    [[clang::musttail]] return foo2 (x, 29);
-+    [[gnu::musttail]] return foo2 (x, 29);
-   if (x < 100)
-     {
-       int k = foo (x + 1);
--      [[clang::musttail]] return k;	/* { dg-error "cannot tail-call: " } */
-+      [[gnu::musttail]] return k;	/* { dg-error "cannot tail-call: " } */
-     }
-   return x;
- }
-diff --git a/gcc/testsuite/g++.dg/musttail14.C b/gcc/testsuite/g++.dg/musttail14.C
-index 810b45546d61..e4764a3bc03b 100644
---- a/gcc/testsuite/g++.dg/musttail14.C
-+++ b/gcc/testsuite/g++.dg/musttail14.C
-@@ -58,8 +58,8 @@ garply (int x)
-     case 3:
-       __attribute__(()) [[gnu::musttail]] __attribute__(()) [[]] __attribute__(()) return qux (45);
-     case 4:
--      [[]] __attribute__(()) [[clang::musttail]] __attribute__(()) [[]] return corge (46);
-+      [[]] __attribute__(()) [[gnu::musttail]] __attribute__(()) [[]] return corge (46);
-     default:
--      __attribute__(()) [[clang::musttail]] __attribute__(()) [[]] __attribute__(()) return freddy (47);
-+      __attribute__(()) [[gnu::musttail]] __attribute__(()) [[]] __attribute__(()) return freddy (47);
-     }
- }
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 2a32843..92b88c3 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,5 @@
 49	????
 
-	+ 77_all_PR119376-Disable-clang-musttail.patch
 	+ 80_all_PR119428.patch
 
 48	24 March 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-25 10:27 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-25 10:27 UTC (permalink / raw
  To: gentoo-commits
commit:     c2a595b9790a24dd84d6fb44ba99c6bb7dd1472b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 25 10:27:33 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Mar 25 10:27:33 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=c2a595b9
15.0.0: drop 79_all_PR117811-arm-neon-shift.patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/79_all_PR117811-arm-neon-shift.patch | 162 ---------------------
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 1 insertion(+), 162 deletions(-)
diff --git a/15.0.0/gentoo/79_all_PR117811-arm-neon-shift.patch b/15.0.0/gentoo/79_all_PR117811-arm-neon-shift.patch
deleted file mode 100644
index 5a78653..0000000
--- a/15.0.0/gentoo/79_all_PR117811-arm-neon-shift.patch
+++ /dev/null
@@ -1,162 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/20250321094756.1044263-1-rearnsha@arm.com/
-
-From db60414d7b3f596214547fc9a7c74fcb38248527 Mon Sep 17 00:00:00 2001
-Message-ID: <db60414d7b3f596214547fc9a7c74fcb38248527.1742577601.git.sam@gentoo.org>
-From: Richard Earnshaw <rearnsha@arm.com>
-Date: Fri, 21 Mar 2025 09:47:56 +0000
-Subject: [PATCH] opcodes: fix wrong code in expand_binop_directly [PR117811]
-
-If expand_binop_directly fails to add a REG_EQUAL note it tries to
-unwind and restart.  But it can unwind too far if expand_binop changed
-some of the operands before calling it.  We don't need to unwind that
-far anyway since we should end up taking exactly the same route next
-time, just without a target rtx.
-
-To fix this we remove LAST from the argument list and let the callers
-(all in expand_binop) do their own unwinding if the call fails.
-Instead we unwind just as far as the entry to expand_binop_directly
-and recurse within this function instead of all the way back up.
-
-gcc/ChangeLog:
-
-	PR middle-end/117811
-	* optabs.cc (expand_binop_directly): Remove LAST as an argument,
-	instead record the last insn on entry.  Only delete insns if
-	we need to restart and restart by calling ourself, not expand_binop.
-	(expand_binop): Update callers to expand_binop_directly.  If it
-	fails to expand the operation, delete back to LAST.
-
-gcc/testsuite:
-
-PR middle-end/117811
-	* gcc.dg/torture/pr117811.c: New test.
----
- gcc/optabs.cc                           | 24 +++++++++++-----------
- gcc/testsuite/gcc.dg/torture/pr117811.c | 27 +++++++++++++++++++++++++
- 2 files changed, 39 insertions(+), 12 deletions(-)
- create mode 100644 gcc/testsuite/gcc.dg/torture/pr117811.c
-
-diff --git a/gcc/optabs.cc b/gcc/optabs.cc
-index 36f2e6af8b5c..0a14b1eef8a5 100644
---- a/gcc/optabs.cc
-+++ b/gcc/optabs.cc
-@@ -1369,8 +1369,7 @@ avoid_expensive_constant (machine_mode mode, optab binoptab,
- static rtx
- expand_binop_directly (enum insn_code icode, machine_mode mode, optab binoptab,
- 		       rtx op0, rtx op1,
--		       rtx target, int unsignedp, enum optab_methods methods,
--		       rtx_insn *last)
-+		       rtx target, int unsignedp, enum optab_methods methods)
- {
-   machine_mode xmode0 = insn_data[(int) icode].operand[1].mode;
-   machine_mode xmode1 = insn_data[(int) icode].operand[2].mode;
-@@ -1380,6 +1379,7 @@ expand_binop_directly (enum insn_code icode, machine_mode mode, optab binoptab,
-   rtx_insn *pat;
-   rtx xop0 = op0, xop1 = op1;
-   bool canonicalize_op1 = false;
-+  rtx_insn *last = get_last_insn ();
- 
-   /* If it is a commutative operator and the modes would match
-      if we would swap the operands, we can save the conversions.  */
-@@ -1444,10 +1444,7 @@ expand_binop_directly (enum insn_code icode, machine_mode mode, optab binoptab,
-       tmp_mode = insn_data[(int) icode].operand[0].mode;
-       if (VECTOR_MODE_P (mode)
- 	  && maybe_ne (GET_MODE_NUNITS (tmp_mode), 2 * GET_MODE_NUNITS (mode)))
--	{
--	  delete_insns_since (last);
--	  return NULL_RTX;
--	}
-+	return NULL_RTX;
-     }
-   else
-     tmp_mode = mode;
-@@ -1467,14 +1464,14 @@ expand_binop_directly (enum insn_code icode, machine_mode mode, optab binoptab,
- 			       ops[1].value, ops[2].value, mode0))
- 	{
- 	  delete_insns_since (last);
--	  return expand_binop (mode, binoptab, op0, op1, NULL_RTX,
--			       unsignedp, methods);
-+	  return expand_binop_directly (icode, mode, binoptab, op0, op1,
-+					NULL_RTX, unsignedp, methods);
- 	}
- 
-       emit_insn (pat);
-       return ops[0].value;
-     }
--  delete_insns_since (last);
-+
-   return NULL_RTX;
- }
- 
-@@ -1543,9 +1540,10 @@ expand_binop (machine_mode mode, optab binoptab, rtx op0, rtx op1,
-       if (icode != CODE_FOR_nothing)
- 	{
- 	  temp = expand_binop_directly (icode, mode, binoptab, op0, op1,
--					target, unsignedp, methods, last);
-+					target, unsignedp, methods);
- 	  if (temp)
- 	    return temp;
-+	  delete_insns_since (last);
- 	}
-     }
- 
-@@ -1571,9 +1569,10 @@ expand_binop (machine_mode mode, optab binoptab, rtx op0, rtx op1,
- 			       NULL_RTX, unsignedp, OPTAB_DIRECT);
- 
-       temp = expand_binop_directly (icode, int_mode, otheroptab, op0, newop1,
--				    target, unsignedp, methods, last);
-+				    target, unsignedp, methods);
-       if (temp)
- 	return temp;
-+      delete_insns_since (last);
-     }
- 
-   /* If this is a multiply, see if we can do a widening operation that
-@@ -1637,9 +1636,10 @@ expand_binop (machine_mode mode, optab binoptab, rtx op0, rtx op1,
- 	  if (vop1)
- 	    {
- 	      temp = expand_binop_directly (icode, mode, otheroptab, op0, vop1,
--					    target, unsignedp, methods, last);
-+					    target, unsignedp, methods);
- 	      if (temp)
- 		return temp;
-+	      delete_insns_since (last);
- 	    }
- 	}
-     }
-diff --git a/gcc/testsuite/gcc.dg/torture/pr117811.c b/gcc/testsuite/gcc.dg/torture/pr117811.c
-new file mode 100644
-index 000000000000..13d7e1347807
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/torture/pr117811.c
-@@ -0,0 +1,27 @@
-+/* { dg-do run } */
-+
-+#include <string.h>
-+
-+typedef int v4 __attribute__((vector_size (4 * sizeof (int))));
-+
-+void __attribute__((noclone,noinline)) do_shift (v4 *vec, int shift)
-+{
-+  v4 t = *vec;
-+
-+  if (shift > 0)
-+  {
-+    t = t >> shift;
-+  }
-+
-+  *vec = t;
-+}
-+
-+int main ()
-+{
-+  v4 vec =  {0x1000000, 0x2000, 0x300, 0x40};
-+  v4 vec2 = {0x100000,  0x200,  0x30,  0x4};
-+  do_shift (&vec, 4);
-+  if (memcmp (&vec, &vec2, sizeof (v4)) != 0)
-+    __builtin_abort ();
-+  return 0;
-+}
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 92b88c3..d822311 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 49	????
 
+	- 79_all_PR117811-arm-neon-shift.patch
 	+ 80_all_PR119428.patch
 
 48	24 March 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-26  6:25 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-26  6:25 UTC (permalink / raw
  To: gentoo-commits
commit:     c0b762d8fa383a9e2d81f5097eaca6c3881ba3ab
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Mar 26 06:25:42 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Mar 26 06:25:42 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=c0b762d8
15.0.0: drop 80_all_PR119428.patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/80_all_PR119428.patch | 56 -------------------------------------
 15.0.0/gentoo/README.history        |  1 -
 2 files changed, 57 deletions(-)
diff --git a/15.0.0/gentoo/80_all_PR119428.patch b/15.0.0/gentoo/80_all_PR119428.patch
deleted file mode 100644
index 45b1bf5..0000000
--- a/15.0.0/gentoo/80_all_PR119428.patch
+++ /dev/null
@@ -1,56 +0,0 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119428#c10
-
-2025-03-24  Jakub Jelinek  <jakub@redhat.com>
-
-	PR target/96226
-	PR target/119428
-	* config/i386/i386.md (splitter after *<rotate_insn><mode>3_mask,
-	splitter after *<rotate_insn><mode>3_mask_1): Revert 2020-12-05
-	changes.
-
-	* gcc.c-torture/execute/pr119428.c: New test.
-
---- a/gcc/config/i386/i386.md	2025-03-24 11:29:12.271793423 +0100
-+++ b/gcc/config/i386/i386.md	2025-03-24 11:32:14.139305881 +0100
-@@ -18168,7 +18168,8 @@ (define_split
-  [(set (match_dup 4) (match_dup 1))
-   (set (match_dup 0)
-        (any_rotate:SWI (match_dup 4)
--		       (subreg:QI (match_dup 2) 0)))]
-+		       (subreg:QI
-+			 (and:SI (match_dup 2) (match_dup 3)) 0)))]
-  "operands[4] = gen_reg_rtx (<MODE>mode);")
- 
- (define_insn_and_split "*<insn><mode>3_mask_1"
-@@ -18202,7 +18203,8 @@ (define_split
-   == GET_MODE_BITSIZE (<MODE>mode) - 1"
-  [(set (match_dup 4) (match_dup 1))
-   (set (match_dup 0)
--       (any_rotate:SWI (match_dup 4) (match_dup 2)))]
-+       (any_rotate:SWI (match_dup 4)
-+		       (and:QI (match_dup 2) (match_dup 3))))]
-  "operands[4] = gen_reg_rtx (<MODE>mode);")
- 
- (define_insn_and_split "*<insn><mode>3_add"
---- a/gcc/testsuite/gcc.c-torture/execute/pr119428.c	2025-03-24 11:41:31.583658619 +0100
-+++ b/gcc/testsuite/gcc.c-torture/execute/pr119428.c	2025-03-24 11:40:37.884395211 +0100
-@@ -0,0 +1,18 @@
-+/* PR target/119428 */
-+
-+__attribute__((noipa)) void
-+foo (unsigned int x, unsigned char *y)
-+{
-+  y += x >> 3;
-+  *y &= (unsigned char) ~(1 << (x & 0x07));
-+}
-+
-+int
-+main ()
-+{
-+  unsigned char buf[8];
-+  __builtin_memset (buf, 0xff, 8);
-+  foo (8, buf);
-+  if (buf[1] != 0xfe)
-+    __builtin_abort ();
-+}
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index d822311..2db87ef 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,7 +1,6 @@
 49	????
 
 	- 79_all_PR117811-arm-neon-shift.patch
-	+ 80_all_PR119428.patch
 
 48	24 March 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-29 13:51 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-29 13:51 UTC (permalink / raw
  To: gentoo-commits
commit:     9745c5273507a0eba8902f36737c0ef3d0219ce1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Mar 29 13:50:50 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Mar 29 13:51:24 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=9745c527
15.0.0: add 35_all_checking-gc-use-heuristics.patch
GCC's --enable-checking=yes includes 'gc' which also then disables the
default (already conservative) GC threshold heuristics.
Bug: https://gcc.gnu.org/PR64500
Bug: https://gcc.gnu.org/PR116285
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../gentoo/35_all_checking-gc-use-heuristics.patch | 22 ++++++++++++++++++++++
 15.0.0/gentoo/README.history                       |  6 +++++-
 2 files changed, 27 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/35_all_checking-gc-use-heuristics.patch b/15.0.0/gentoo/35_all_checking-gc-use-heuristics.patch
new file mode 100644
index 0000000..35ba553
--- /dev/null
+++ b/15.0.0/gentoo/35_all_checking-gc-use-heuristics.patch
@@ -0,0 +1,22 @@
+GCC's --enable-checking=yes includes 'gc' which also then disables the
+default (already conservative) GC threshold heuristics.
+--- a/gcc/ggc-common.cc
++++ b/gcc/ggc-common.cc
+@@ -1029,7 +1029,7 @@ mmap_gt_pch_use_address (void *&base, size_t size, int fd, size_t offset)
+ }
+ #endif /* HAVE_MMAP_FILE */
+ 
+-#if !defined ENABLE_GC_CHECKING && !defined ENABLE_GC_ALWAYS_COLLECT
++#if !defined ENABLE_GC_ALWAYS_COLLECT
+ 
+ /* Modify the bound based on rlimits.  */
+ static double
+@@ -1126,7 +1126,7 @@ ggc_min_heapsize_heuristic (void)
+ void
+ init_ggc_heuristics (void)
+ {
+-#if !defined ENABLE_GC_CHECKING && !defined ENABLE_GC_ALWAYS_COLLECT
++#if !defined ENABLE_GC_ALWAYS_COLLECT
+   param_ggc_min_expand = ggc_min_expand_heuristic ();
+   param_ggc_min_heapsize = ggc_min_heapsize_heuristic ();
+ #endif
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 2db87ef..7a993e4 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,8 @@
-49	????
+50	????
+
+	+ 35_all_checking-gc-use-heuristics.patch
+
+49	26 March 2025
 
 	- 79_all_PR117811-arm-neon-shift.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-29 14:33 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-29 14:33 UTC (permalink / raw
  To: gentoo-commits
commit:     c2b5b58acd2b0240ed361bbc9a94bf61d2d26f8e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Mar 29 14:32:21 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Mar 29 14:33:06 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=c2b5b58a
15.0.0: add 2 combine patches
Bug: https://gcc.gnu.org/PR119291
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-reg_used_between_p-rather-than-modified_.patch | 196 +++++++++++++++++++++
 ...bine-Special-case-set_noop_p-in-two-spots.patch |  96 ++++++++++
 15.0.0/gentoo/README.history                       |   2 +
 3 files changed, 294 insertions(+)
diff --git a/15.0.0/gentoo/78_all_PR119291-combine-Use-reg_used_between_p-rather-than-modified_.patch b/15.0.0/gentoo/78_all_PR119291-combine-Use-reg_used_between_p-rather-than-modified_.patch
new file mode 100644
index 0000000..3264869
--- /dev/null
+++ b/15.0.0/gentoo/78_all_PR119291-combine-Use-reg_used_between_p-rather-than-modified_.patch
@@ -0,0 +1,196 @@
+https://inbox.sourceware.org/gcc-patches/Z+aDTloxATzkpTbQ@tucnak/
+
+From 8db4ff073981a554ab5b77f958fa4a333b981b30 Mon Sep 17 00:00:00 2001
+Message-ID: <8db4ff073981a554ab5b77f958fa4a333b981b30.1743258660.git.sam@gentoo.org>
+From: Jakub Jelinek <jakub@redhat.com>
+Date: Fri, 28 Mar 2025 12:09:02 +0100
+Subject: [PATCH 1/2] combine: Use reg_used_between_p rather than
+ modified_between_p in two spots [PR119291]
+
+Hi!
+
+The following testcase is miscompiled on x86_64-linux at -O2 by the combiner.
+We have from earlier combinations
+(insn 22 21 23 4 (set (reg:SI 104 [ _7 ])
+        (const_int 0 [0])) "pr119291.c":25:15 96 {*movsi_internal}
+     (nil))
+(insn 23 22 24 4 (set (reg/v:SI 117 [ e ])
+        (reg/v:SI 116 [ e ])) 96 {*movsi_internal}
+     (expr_list:REG_DEAD (reg/v:SI 116 [ e ])
+        (nil)))
+(note 24 23 25 4 NOTE_INSN_DELETED)
+(insn 25 24 26 4 (parallel [
+            (set (reg:CCZ 17 flags)
+                (compare:CCZ (neg:SI (reg:SI 104 [ _7 ]))
+                    (const_int 0 [0])))
+            (set (reg/v:SI 116 [ e ])
+                (neg:SI (reg:SI 104 [ _7 ])))
+        ]) "pr119291.c":26:13 977 {*negsi_2}
+     (expr_list:REG_DEAD (reg:SI 104 [ _7 ])
+        (nil)))
+(note 26 25 27 4 NOTE_INSN_DELETED)
+(insn 27 26 28 4 (set (reg:DI 128 [ _9 ])
+        (ne:DI (reg:CCZ 17 flags)
+            (const_int 0 [0]))) "pr119291.c":26:13 1447 {*setcc_di_1}
+     (expr_list:REG_DEAD (reg:CCZ 17 flags)
+        (nil)))
+and try_combine is called on i3 25 and i2 22 (second time)
+and reach the hunk being patched with simplified i3
+(insn 25 24 26 4 (parallel [
+            (set (pc)
+                (pc))
+            (set (reg/v:SI 116 [ e ])
+                (const_int 0 [0]))
+        ]) "pr119291.c":28:13 977 {*negsi_2}
+     (expr_list:REG_DEAD (reg:SI 104 [ _7 ])
+        (nil)))
+and
+(insn 22 21 23 4 (set (reg:SI 104 [ _7 ])
+        (const_int 0 [0])) "pr119291.c":27:15 96 {*movsi_internal}
+     (nil))
+Now, the try_combine code there attempts to split two independent
+sets in newpat by moving one of them to i2.
+And among other tests it checks
+!modified_between_p (SET_DEST (set1), i2, i3)
+which is certainly needed, if there would be say
+(set (reg/v:SI 116 [ e ]) (const_int 42 [0x2a]))
+in between i2 and i3, we couldn't do that, as that set would overwrite
+the value set by set1 we want to move to the i2 position.
+But in this case pseudo 116 isn't set in between i2 and i3, but used
+(and additionally there is a REG_DEAD note for it).
+
+This is equally bad for the move, because while the i3 insn
+and later will see the pseudo value that we set, the insn in between
+which uses the value will see a different value from the one that
+it should see.
+
+As we don't check for that, in the end try_combine succeeds and
+changes the IL to:
+(insn 22 21 23 4 (set (reg/v:SI 116 [ e ])
+        (const_int 0 [0])) "pr119291.c":27:15 96 {*movsi_internal}
+     (nil))
+(insn 23 22 24 4 (set (reg/v:SI 117 [ e ])
+        (reg/v:SI 116 [ e ])) 96 {*movsi_internal}
+     (expr_list:REG_DEAD (reg/v:SI 116 [ e ])
+        (nil)))
+(note 24 23 25 4 NOTE_INSN_DELETED)
+(insn 25 24 26 4 (set (pc)
+        (pc)) "pr119291.c":28:13 2147483647 {NOOP_MOVE}
+     (nil))
+(note 26 25 27 4 NOTE_INSN_DELETED)
+(insn 27 26 28 4 (set (reg:DI 128 [ _9 ])
+        (const_int 0 [0])) "pr119291.c":28:13 95 {*movdi_internal}
+     (nil))
+(note, the i3 got turned into a nop and try_combine also modified insn 27).
+
+The following patch replaces the modified_between_p
+tests with reg_used_between_p, my understanding is that
+modified_between_p is a subset of reg_used_between_p, so one
+doesn't need both.
+
+Bootstrapped/regtested on x86_64-linux, i686-linux, aarch64-linux,
+powerpc64le-linux and s390x-linux, ok for trunk?
+
+Looking at this some more today, I think we should special case
+set_noop_p because that can be put into i2 (except for the JUMP_P
+violations), currently both modified_between_p (pc_rtx, i2, i3)
+and reg_used_between_p (pc_rtx, i2, i3) returns false.
+I'll post a patch incrementally for that (but that feels like
+new optimization, so probably not something that should be backported).
+
+2025-03-28  Jakub Jelinek  <jakub@redhat.com>
+
+	PR rtl-optimization/119291
+	* combine.cc (try_combine): For splitting of PARALLEL with
+	2 independent SETs into i2 and i3 sets check reg_used_between_p
+	of the SET_DESTs rather than just modified_between_p.
+
+	* gcc.c-torture/execute/pr119291.c: New test.
+---
+ gcc/combine.cc                                | 14 ++++----
+ .../gcc.c-torture/execute/pr119291.c          | 33 +++++++++++++++++++
+ 2 files changed, 40 insertions(+), 7 deletions(-)
+ create mode 100644 gcc/testsuite/gcc.c-torture/execute/pr119291.c
+
+diff --git a/gcc/combine.cc b/gcc/combine.cc
+index ef13f5d5e900..e87a9f272f1a 100644
+--- a/gcc/combine.cc
++++ b/gcc/combine.cc
+@@ -4012,18 +4012,18 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
+       rtx set1 = XVECEXP (newpat, 0, 1);
+ 
+       /* Normally, it doesn't matter which of the two is done first, but
+-	 one which uses any regs/memory set in between i2 and i3 can't
+-	 be first.  The PARALLEL might also have been pre-existing in i3,
+-	 so we need to make sure that we won't wrongly hoist a SET to i2
+-	 that would conflict with a death note present in there, or would
+-	 have its dest modified between i2 and i3.  */
++	 one which uses any regs/memory set or used in between i2 and i3
++	 can't be first.  The PARALLEL might also have been pre-existing
++	 in i3, so we need to make sure that we won't wrongly hoist a SET
++	 to i2 that would conflict with a death note present in there, or
++	 would have its dest modified or used between i2 and i3.  */
+       if (!modified_between_p (SET_SRC (set1), i2, i3)
+ 	  && !(REG_P (SET_DEST (set1))
+ 	       && find_reg_note (i2, REG_DEAD, SET_DEST (set1)))
+ 	  && !(GET_CODE (SET_DEST (set1)) == SUBREG
+ 	       && find_reg_note (i2, REG_DEAD,
+ 				 SUBREG_REG (SET_DEST (set1))))
+-	  && !modified_between_p (SET_DEST (set1), i2, i3)
++	  && !reg_used_between_p (SET_DEST (set1), i2, i3)
+ 	  /* If I3 is a jump, ensure that set0 is a jump so that
+ 	     we do not create invalid RTL.  */
+ 	  && (!JUMP_P (i3) || SET_DEST (set0) == pc_rtx)
+@@ -4038,7 +4038,7 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
+ 	       && !(GET_CODE (SET_DEST (set0)) == SUBREG
+ 		    && find_reg_note (i2, REG_DEAD,
+ 				      SUBREG_REG (SET_DEST (set0))))
+-	       && !modified_between_p (SET_DEST (set0), i2, i3)
++	       && !reg_used_between_p (SET_DEST (set0), i2, i3)
+ 	       /* If I3 is a jump, ensure that set1 is a jump so that
+ 		  we do not create invalid RTL.  */
+ 	       && (!JUMP_P (i3) || SET_DEST (set1) == pc_rtx)
+diff --git a/gcc/testsuite/gcc.c-torture/execute/pr119291.c b/gcc/testsuite/gcc.c-torture/execute/pr119291.c
+new file mode 100644
+index 000000000000..41eadf013d7d
+--- /dev/null
++++ b/gcc/testsuite/gcc.c-torture/execute/pr119291.c
+@@ -0,0 +1,33 @@
++/* PR rtl-optimization/119291 */
++
++int a;
++long c;
++
++__attribute__((noipa)) void
++foo (int x)
++{
++  if (x != 0)
++    __builtin_abort ();
++  a = 42;
++}
++
++int
++main ()
++{
++  int e = 1;
++lab:
++  if (a < 2)
++    {
++      int b = e;
++      _Bool d = a != 0;
++      _Bool f = b != 0;
++      unsigned long g = -(d & f);
++      unsigned long h = c & g;
++      unsigned long i = ~c;
++      e = -(i & h);
++      c = e != 0;
++      a = ~e + b;
++      foo (e);
++      goto lab;
++    }
++}
+
+base-commit: 9018336252463ffed28f01badfdea2a3ca3ba5c8
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/79_all_PR119291-combine-Special-case-set_noop_p-in-two-spots.patch b/15.0.0/gentoo/79_all_PR119291-combine-Special-case-set_noop_p-in-two-spots.patch
new file mode 100644
index 0000000..1cf964d
--- /dev/null
+++ b/15.0.0/gentoo/79_all_PR119291-combine-Special-case-set_noop_p-in-two-spots.patch
@@ -0,0 +1,96 @@
+https://inbox.sourceware.org/gcc-patches/Z+aF8pEePd6K5xKf@tucnak/
+
+From fd39f47728c4e81e75c7150199fa368646cde9c3 Mon Sep 17 00:00:00 2001
+Message-ID: <fd39f47728c4e81e75c7150199fa368646cde9c3.1743258660.git.sam@gentoo.org>
+In-Reply-To: <8db4ff073981a554ab5b77f958fa4a333b981b30.1743258660.git.sam@gentoo.org>
+References: <8db4ff073981a554ab5b77f958fa4a333b981b30.1743258660.git.sam@gentoo.org>
+From: Jakub Jelinek <jakub@redhat.com>
+Date: Fri, 28 Mar 2025 12:20:18 +0100
+Subject: [PATCH 2/2] combine: Special case set_noop_p in two spots
+
+Hi!
+
+Here is the incremental patch I was talking about.
+For noop sets, we don't need to test much, they can go to i2
+unless that would violate i3 JUMP condition.
+
+With this the try_combine on the pr119291.c testcase doesn't fail,
+but succeeds and we get
+(insn 22 21 23 4 (set (pc)
+        (pc)) "pr119291.c":27:15 2147483647 {NOOP_MOVE}
+     (nil))
+(insn 23 22 24 4 (set (reg/v:SI 117 [ e ])
+        (reg/v:SI 116 [ e ])) 96 {*movsi_internal}
+     (expr_list:REG_DEAD (reg/v:SI 116 [ e ])
+        (nil)))
+(note 24 23 25 4 NOTE_INSN_DELETED)
+(insn 25 24 26 4 (set (reg/v:SI 116 [ e ])
+        (const_int 0 [0])) "pr119291.c":28:13 96 {*movsi_internal}
+     (nil))
+(note 26 25 27 4 NOTE_INSN_DELETED)
+(insn 27 26 28 4 (set (reg:DI 128 [ _9 ])
+        (const_int 0 [0])) "pr119291.c":28:13 95 {*movdi_internal}
+     (nil))
+after it.
+
+Ok for trunk if this passes bootstrap/regtest?
+
+2025-03-28  Jakub Jelinek  <jakub@redhat.com>
+
+	* combine.cc (try_combine): Sets which satisfy set_noop_p can go
+	to i2 unless i3 is a jump and the other set is not.
+---
+ gcc/combine.cc | 30 ++++++++++++++++--------------
+ 1 file changed, 16 insertions(+), 14 deletions(-)
+
+diff --git a/gcc/combine.cc b/gcc/combine.cc
+index e87a9f272f1a..2be563bb018c 100644
+--- a/gcc/combine.cc
++++ b/gcc/combine.cc
+@@ -4017,13 +4017,14 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
+ 	 in i3, so we need to make sure that we won't wrongly hoist a SET
+ 	 to i2 that would conflict with a death note present in there, or
+ 	 would have its dest modified or used between i2 and i3.  */
+-      if (!modified_between_p (SET_SRC (set1), i2, i3)
+-	  && !(REG_P (SET_DEST (set1))
+-	       && find_reg_note (i2, REG_DEAD, SET_DEST (set1)))
+-	  && !(GET_CODE (SET_DEST (set1)) == SUBREG
+-	       && find_reg_note (i2, REG_DEAD,
+-				 SUBREG_REG (SET_DEST (set1))))
+-	  && !reg_used_between_p (SET_DEST (set1), i2, i3)
++      if ((set_noop_p (set1)
++	   || (!modified_between_p (SET_SRC (set1), i2, i3)
++	       && !(REG_P (SET_DEST (set1))
++		    && find_reg_note (i2, REG_DEAD, SET_DEST (set1)))
++	       && !(GET_CODE (SET_DEST (set1)) == SUBREG
++		    && find_reg_note (i2, REG_DEAD,
++				      SUBREG_REG (SET_DEST (set1))))
++	       && !reg_used_between_p (SET_DEST (set1), i2, i3)))
+ 	  /* If I3 is a jump, ensure that set0 is a jump so that
+ 	     we do not create invalid RTL.  */
+ 	  && (!JUMP_P (i3) || SET_DEST (set0) == pc_rtx)
+@@ -4032,13 +4033,14 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
+ 	  newi2pat = set1;
+ 	  newpat = set0;
+ 	}
+-      else if (!modified_between_p (SET_SRC (set0), i2, i3)
+-	       && !(REG_P (SET_DEST (set0))
+-		    && find_reg_note (i2, REG_DEAD, SET_DEST (set0)))
+-	       && !(GET_CODE (SET_DEST (set0)) == SUBREG
+-		    && find_reg_note (i2, REG_DEAD,
+-				      SUBREG_REG (SET_DEST (set0))))
+-	       && !reg_used_between_p (SET_DEST (set0), i2, i3)
++      else if ((set_noop_p (set0)
++		|| (!modified_between_p (SET_SRC (set0), i2, i3)
++		    && !(REG_P (SET_DEST (set0))
++			 && find_reg_note (i2, REG_DEAD, SET_DEST (set0)))
++		    && !(GET_CODE (SET_DEST (set0)) == SUBREG
++			 && find_reg_note (i2, REG_DEAD,
++					   SUBREG_REG (SET_DEST (set0))))
++		    && !reg_used_between_p (SET_DEST (set0), i2, i3)))
+ 	       /* If I3 is a jump, ensure that set1 is a jump so that
+ 		  we do not create invalid RTL.  */
+ 	       && (!JUMP_P (i3) || SET_DEST (set1) == pc_rtx)
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 7a993e4..70acf07 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,8 @@
 50	????
 
 	+ 35_all_checking-gc-use-heuristics.patch
+	+ 78_all_PR119291-combine-Use-reg_used_between_p-rather-than-modified_.patch
+	+ 79_all_PR119291-combine-Special-case-set_noop_p-in-two-spots.patch
 
 49	26 March 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-29 20:31 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-29 20:31 UTC (permalink / raw
  To: gentoo-commits
commit:     0d85fc98e02a17cd0e5315bb722f3dbeab3f737b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Mar 29 20:30:56 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Mar 29 20:30:56 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=0d85fc98
15.0.0: add 80_all_PR119376-tailc-Don-t-fail-musttail-calls-if-they-use-or-could.patch
Bug: https://gcc.gnu.org/PR119376
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-fail-musttail-calls-if-they-use-or-could.patch | 1124 ++++++++++++++++++++
 15.0.0/gentoo/README.history                       |    1 +
 2 files changed, 1125 insertions(+)
diff --git a/15.0.0/gentoo/80_all_PR119376-tailc-Don-t-fail-musttail-calls-if-they-use-or-could.patch b/15.0.0/gentoo/80_all_PR119376-tailc-Don-t-fail-musttail-calls-if-they-use-or-could.patch
new file mode 100644
index 0000000..d906b0c
--- /dev/null
+++ b/15.0.0/gentoo/80_all_PR119376-tailc-Don-t-fail-musttail-calls-if-they-use-or-could.patch
@@ -0,0 +1,1124 @@
+https://inbox.sourceware.org/gcc-patches/Z+JccoSNxYWZIPz5@tucnak/
+
+From 4c5f092df307ec34b842483b1702d2e173e592a5 Mon Sep 17 00:00:00 2001
+Message-ID: <4c5f092df307ec34b842483b1702d2e173e592a5.1743280205.git.sam@gentoo.org>
+From: Jakub Jelinek <jakub@redhat.com>
+Date: Tue, 25 Mar 2025 08:34:10 +0100
+Subject: [PATCH] tailc: Don't fail musttail calls if they use or could use
+ local arguments, instead warn [PR119376]
+
+Hi!
+
+As discussed here and in bugzilla, [[clang::musttail]] attribute in clang
+not just strongly asks for tail call or error, but changes behavior.
+To quote:
+https://clang.llvm.org/docs/AttributeReference.html#musttail
+"The lifetimes of all local variables and function parameters end immediately
+before the call to the function.  This means that it is undefined behaviour
+to pass a pointer or reference to a local variable to the called function,
+which is not the case without the attribute.  Clang will emit a warning in
+common cases where this happens."
+
+The GCC behavior was just to error if we can't prove the musttail callee
+could not have dereferenced escaped pointers to local vars or parameters
+of the caller.  That is still the case for variables with non-trivial
+destruction (even in clang), like vars with C++ non-trivial destructors or
+variables with cleanup attribute.
+
+The following patch changes the behavior to match that of clang, for all of
+[[clang::musttail]], [[gnu::musttail]] and __attribute__((musttail)).
+
+clang 20 actually added warning for some cases of it in
+https://github.com/llvm/llvm-project/pull/109255
+but it is under -Wreturn-stack-address warning.
+
+Now, gcc doesn't have that warning, but -Wreturn-local-addr instead, and
+IMHO it is better to have this under new warnings, because this isn't about
+returning local address, but about passing it to a musttail call, or maybe
+escaping to a musttail call.  And perhaps users will appreciate they can
+control it separately as well.
+
+The patch introduces 2 new warnings.
+-Wmusttail-local-addr
+which is turn on by default and warns for the always dumb cases of passing
+an address of a local variable or parameter to musttail call's argument.
+And then
+-Wmaybe-musttail-local-addr
+which is only diagnosed if -Wmusttail-local-addr was not diagnosed and
+diagnoses at most one (so that we don't emit 100s of warnings for one call
+if 100s of vars can escape) case where an address of a local var could have
+escaped to the musttail call.  This is less severe, the code doesn't have
+to be obviously wrong, so the warning is only enabled in -Wextra.
+
+And I've adjusted also the documentation for this change and addition of
+new warnings.
+
+Bootstrapped/regtested on x86_64-linux and i686-linux (on top of the
+just posted patch), ok for trunk?
+
+2025-03-25  Jakub Jelinek  <jakub@redhat.com>
+
+	PR ipa/119376
+	* common.opt (Wmusttail-local-addr, Wmaybe-musttail-local-addr): New.
+	* tree-tailcall.cc (suitable_for_tail_call_opt_p): Don't fail for
+	TREE_ADDRESSABLE PARM_DECLs for musttail calls if diag_musttail.
+	Emit -Wmusttail-local-addr warnings.
+	(maybe_error_musttail): Use gimple_location instead of directly
+	accessing location member.
+	(find_tail_calls): For musttail calls if diag_musttail, don't fail
+	if address of local could escape to the call, instead emit
+	-Wmaybe-musttail-local-addr warnings.  Emit
+	-Wmaybe-musttail-local-addr warnings also for address taken
+	parameters.
+	* common.opt.urls: Regenerate.
+	* doc/extend.texi (musttail statement attribute): Clarify local
+	variables without non-trivial destruction are considered out of scope
+	before the tail call instruction.
+	* doc/invoke.texi (-Wno-musttail-local-addr,
+	-Wmaybe-musttail-local-addr): Document.
+
+	* c-c++-common/musttail8.c: Expect a warning rather than error in one
+	case.
+	(f4): Add int * argument.
+	* c-c++-common/musttail15.c: Don't disallow for C++98.
+	* c-c++-common/musttail16.c: Likewise.
+	* c-c++-common/musttail17.c: Likewise.
+	* c-c++-common/musttail18.c: Likewise.
+	* c-c++-common/musttail19.c: Likewise.  Expect a warning rather than
+	error in one case.
+	(f4): Add int * argument.
+	* c-c++-common/musttail20.c: Don't disallow for C++98.
+	* c-c++-common/musttail21.c: Likewise.
+	* c-c++-common/musttail28.c: New test.
+	* c-c++-common/musttail29.c: New test.
+	* c-c++-common/musttail30.c: New test.
+	* c-c++-common/musttail31.c: New test.
+	* g++.dg/ext/musttail1.C: New test.
+	* g++.dg/ext/musttail2.C: New test.
+	* g++.dg/ext/musttail3.C: New test.
+---
+ gcc/common.opt                          |   8 ++
+ gcc/common.opt.urls                     |   6 ++
+ gcc/doc/extend.texi                     |  49 ++++++++++-
+ gcc/doc/invoke.texi                     |  52 ++++++++++-
+ gcc/testsuite/c-c++-common/musttail15.c |   2 +-
+ gcc/testsuite/c-c++-common/musttail16.c |   2 +-
+ gcc/testsuite/c-c++-common/musttail17.c |   2 +-
+ gcc/testsuite/c-c++-common/musttail18.c |   2 +-
+ gcc/testsuite/c-c++-common/musttail19.c |   7 +-
+ gcc/testsuite/c-c++-common/musttail20.c |   2 +-
+ gcc/testsuite/c-c++-common/musttail21.c |   2 +-
+ gcc/testsuite/c-c++-common/musttail28.c | 108 +++++++++++++++++++++++
+ gcc/testsuite/c-c++-common/musttail29.c | 109 ++++++++++++++++++++++++
+ gcc/testsuite/c-c++-common/musttail30.c | 109 ++++++++++++++++++++++++
+ gcc/testsuite/c-c++-common/musttail31.c | 109 ++++++++++++++++++++++++
+ gcc/testsuite/c-c++-common/musttail8.c  |   5 +-
+ gcc/testsuite/g++.dg/ext/musttail1.C    |  38 +++++++++
+ gcc/testsuite/g++.dg/ext/musttail2.C    |  38 +++++++++
+ gcc/testsuite/g++.dg/ext/musttail3.C    |  37 ++++++++
+ gcc/tree-tailcall.cc                    |  97 +++++++++++++++++++--
+ 20 files changed, 760 insertions(+), 24 deletions(-)
+ create mode 100644 gcc/testsuite/c-c++-common/musttail28.c
+ create mode 100644 gcc/testsuite/c-c++-common/musttail29.c
+ create mode 100644 gcc/testsuite/c-c++-common/musttail30.c
+ create mode 100644 gcc/testsuite/c-c++-common/musttail31.c
+ create mode 100644 gcc/testsuite/g++.dg/ext/musttail1.C
+ create mode 100644 gcc/testsuite/g++.dg/ext/musttail2.C
+ create mode 100644 gcc/testsuite/g++.dg/ext/musttail3.C
+
+diff --git a/gcc/common.opt b/gcc/common.opt
+index 2da02866ca08..9400c4b94e88 100644
+--- a/gcc/common.opt
++++ b/gcc/common.opt
+@@ -693,6 +693,14 @@ Does nothing. Preserved for backward compatibility.
+ Wmissing-noreturn
+ Common Warning Alias(Wsuggest-attribute=noreturn)
+ 
++Wmusttail-local-addr
++Common Var(warn_musttail_local_addr) Init(1) Warning
++Warn about passing a pointer/reference to a local or temporary variable to a musttail call argument.
++
++Wmaybe-musttail-local-addr
++Common Var(warn_maybe_musttail_local_addr) Warning EnabledBy(Wextra)
++Warn about pointer/reference to a local or temporary variable possibly escaping to a musttail call.
++
+ Wodr
+ Common Var(warn_odr_violations) Init(1) Warning
+ Warn about some C++ One Definition Rule violations during link time optimization.
+diff --git a/gcc/common.opt.urls b/gcc/common.opt.urls
+index e7900c825c17..860ebd01ace2 100644
+--- a/gcc/common.opt.urls
++++ b/gcc/common.opt.urls
+@@ -157,6 +157,12 @@ UrlSuffix(gcc/Warning-Options.html#index-Wno-unsafe-loop-optimizations)
+ Wmissing-noreturn
+ UrlSuffix(gcc/Warning-Options.html#index-Wmissing-noreturn)
+ 
++Wmusttail-local-addr
++UrlSuffix(gcc/Warning-Options.html#index-Wno-musttail-local-addr)
++
++Wmaybe-musttail-local-addr
++UrlSuffix(gcc/Warning-Options.html#index-Wmaybe-musttail-local-addr)
++
+ Wodr
+ UrlSuffix(gcc/Warning-Options.html#index-Wno-odr)
+ 
+diff --git a/gcc/doc/extend.texi b/gcc/doc/extend.texi
+index ed766e53dcc4..fcb6df95dcf5 100644
+--- a/gcc/doc/extend.texi
++++ b/gcc/doc/extend.texi
+@@ -9282,10 +9282,51 @@ __attribute__((musttail)) return bar();
+ 
+ If the compiler cannot generate a @code{musttail} tail call it will report
+ an error.  On some targets tail calls may never be supported.
+-Tail calls cannot reference locals in memory, which may affect
+-builds without optimization when passing small structures, or passing
+-or returning large structures.  Enabling @option{-O1} or @option{-O2} can
+-improve the success of tail calls.
++The user asserts for @code{musttail} tail calls that lifetime of automatic
++variables, function parameters and temporaries (unless they have non-trivial
++destruction) can end before the actual call instruction and that any access
++to those from inside of the called function results is considered undefined
++behavior.  Enabling @option{-O1} or @option{-O2} can improve the success of
++tail calls.
++
++@smallexample
++int foo (int *);
++void bar (int *);
++struct S @{ S (); ~S (); int s; @};
++
++int
++baz (int *x)
++@{
++  if (*x == 1)
++    @{
++      int a = 42;
++      /* The call will be tail called (would not be without the
++         attribute), dereferencing the pointer in the callee is
++         undefined behavior and there will be a warning emitted
++         for this by default (@option{-Wmusttail-local-addr}).  */
++      [[gnu::musttail]] return foo (&a);
++    @}
++  else if (*x == 2)
++    @{
++      int a = 42;
++      bar (&a);
++      /* The call will be tail called (would not be without the
++         attribute), if bar stores the pointer anywhere, dereferencing
++         it in foo will be undefined behavior and there will be a warning
++         emitted for this with @option{-Wextra}, which implies
++         @option{-Wmaybe-musttail-local-addr}.  */
++      [[gnu::musttail]] return foo (nullptr);
++    @}
++  else
++    @{
++      S s;
++      /* The s variable requires non-trivial destruction which ought
++         to be performed after the foo call returns, so this will
++         be rejected.  */
++      [[gnu::musttail]] return foo (&s.s);
++    @}
++@}
++@end smallexample
+ @end table
+ 
+ @node Attribute Syntax
+diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
+index df4610908243..2617406b7691 100644
+--- a/gcc/doc/invoke.texi
++++ b/gcc/doc/invoke.texi
+@@ -394,7 +394,8 @@ Objective-C and Objective-C++ Dialects}.
+ -Wmemset-elt-size  -Wmemset-transposed-args
+ -Wmisleading-indentation  -Wmissing-attributes  -Wmissing-braces
+ -Wmissing-field-initializers  -Wmissing-format-attribute
+--Wmissing-include-dirs  -Wmissing-noreturn  -Wno-missing-profile
++-Wmissing-include-dirs  -Wmissing-noreturn  -Wmusttail-local-addr
++-Wmaybe-musttail-local-addr  -Wno-missing-profile
+ -Wno-multichar  -Wmultistatement-macros  -Wnonnull  -Wnonnull-compare
+ -Wnormalized=@r{[}none@r{|}id@r{|}nfc@r{|}nfkc@r{]}
+ -Wnull-dereference  -Wno-odr
+@@ -6975,6 +6976,55 @@ is only active when @option{-fdelete-null-pointer-checks} is active,
+ which is enabled by optimizations in most targets.  The precision of
+ the warnings depends on the optimization options used.
+ 
++@opindex Wno-musttail-local-addr
++@opindex -Wmusttail-local-addr
++@item -Wno-musttail-local-addr
++Do not warn about passing a pointer (or in C++, a reference) to a
++local variable or label to argument of a @code{musttail} call.  Those
++variables go out of scope before the tail call instruction.
++
++@opindex Wmaybe-musttail-local-addr
++@opindex -Wno-maybe-musttail-local-addr
++@item -Wmaybe-musttail-local-addr
++Warn when address of a local variable can escape to a @code{musttail}
++call, unless it goes out of scope already before the @code{musttail}
++call.
++
++@smallexample
++int foo (int *);
++
++int
++bar (int *x)
++@{
++  if (x[0] == 1)
++    @{
++      int a = 42;
++      foo (&a);
++      /* Without the @code{musttail} attribute this call would not
++         be tail called, because address of the @code{a} variable escapes
++         and the second foo call could dereference it.  With the attribute
++         the local variables are assumed to go out of scope immediately
++         before the tail call instruction and the compiler warns about
++         this.  */
++      [[gnu::musttail]] return foo (nullptr);
++    @}
++  else
++    @{
++      @{
++        int a = 42;
++        foo (&a);
++      @}
++      /* The @code{a} variable isn't already in scope, so even when it
++         escaped, even without @code{musttail} attribute it would be
++         undefined behavior to dereference it and the compiler could
++         turn this into a tail call.  No warning is diagnosed here.  */
++      [[gnu::musttail]] return foo (nullptr);
++    @}
++@}
++@end smallexample
++
++This warning is enabled by @option{-Wextra}.
++
+ @opindex Wnrvo
+ @opindex Wno-nrvo
+ @item -Wnrvo @r{(C++ and Objective-C++ only)}
+diff --git a/gcc/testsuite/c-c++-common/musttail15.c b/gcc/testsuite/c-c++-common/musttail15.c
+index 2addc971922c..b8223d77fd56 100644
+--- a/gcc/testsuite/c-c++-common/musttail15.c
++++ b/gcc/testsuite/c-c++-common/musttail15.c
+@@ -1,4 +1,4 @@
+-/* { dg-do compile { target { musttail && { c || c++11 } } } } */
++/* { dg-do compile { target musttail } } */
+ /* { dg-additional-options "-fdelayed-branch" { target sparc*-*-* } } */
+ 
+ int __attribute__((noinline,noclone,noipa))
+diff --git a/gcc/testsuite/c-c++-common/musttail16.c b/gcc/testsuite/c-c++-common/musttail16.c
+index b1e2ff3e6dc8..f27a27923314 100644
+--- a/gcc/testsuite/c-c++-common/musttail16.c
++++ b/gcc/testsuite/c-c++-common/musttail16.c
+@@ -1,4 +1,4 @@
+-/* { dg-do compile { target { musttail && { c || c++11 } } } } */
++/* { dg-do compile { target musttail } } */
+ 
+ struct box { char field[256]; int i; };
+ 
+diff --git a/gcc/testsuite/c-c++-common/musttail17.c b/gcc/testsuite/c-c++-common/musttail17.c
+index 490f3c35ca23..58fab84993bf 100644
+--- a/gcc/testsuite/c-c++-common/musttail17.c
++++ b/gcc/testsuite/c-c++-common/musttail17.c
+@@ -1,4 +1,4 @@
+-/* { dg-do compile { target { musttail && { c || c++11 } } } } */
++/* { dg-do compile { target musttail } } */
+ 
+ struct box { char field[64]; int i; };
+ 
+diff --git a/gcc/testsuite/c-c++-common/musttail18.c b/gcc/testsuite/c-c++-common/musttail18.c
+index 4f34a8d27f36..ab608871fd08 100644
+--- a/gcc/testsuite/c-c++-common/musttail18.c
++++ b/gcc/testsuite/c-c++-common/musttail18.c
+@@ -1,4 +1,4 @@
+-/* { dg-do compile { target { musttail && { c || c++11 } } } } */
++/* { dg-do compile { target musttail } } */
+ /* { dg-additional-options "-fdelayed-branch" { target sparc*-*-* } } */
+ 
+ void __attribute__((noipa)) f() {}
+diff --git a/gcc/testsuite/c-c++-common/musttail19.c b/gcc/testsuite/c-c++-common/musttail19.c
+index 70f9eaff139c..a592b69c1b7c 100644
+--- a/gcc/testsuite/c-c++-common/musttail19.c
++++ b/gcc/testsuite/c-c++-common/musttail19.c
+@@ -1,4 +1,4 @@
+-/* { dg-do compile { target { musttail && { c || c++11 } } } } */
++/* { dg-do compile { target musttail } } */
+ 
+ float f1(void);
+ 
+@@ -10,8 +10,9 @@ int f2(void)
+ 
+ int f3(int *);
+ 
+-int f4(void)
++int f4(int *p)
+ {
+   int x;
+-  __attribute__((musttail)) return f3(&x); /* { dg-error "\(refers to locals|other reasons\)" } */
++  (void) p;
++  __attribute__((musttail)) return f3(&x); /* { dg-warning "address of automatic variable 'x' passed to 'musttail' call argument" } */
+ }
+diff --git a/gcc/testsuite/c-c++-common/musttail20.c b/gcc/testsuite/c-c++-common/musttail20.c
+index 70f14ff2f217..1931f2cc8e4a 100644
+--- a/gcc/testsuite/c-c++-common/musttail20.c
++++ b/gcc/testsuite/c-c++-common/musttail20.c
+@@ -1,4 +1,4 @@
+-/* { dg-do compile { target { struct_musttail && { c || c++11 } } } } */
++/* { dg-do compile { target struct_musttail } } */
+ /* { dg-additional-options "-fdelayed-branch" { target sparc*-*-* } } */
+ 
+ struct str
+diff --git a/gcc/testsuite/c-c++-common/musttail21.c b/gcc/testsuite/c-c++-common/musttail21.c
+index 954209ddcd51..1a109e1955dc 100644
+--- a/gcc/testsuite/c-c++-common/musttail21.c
++++ b/gcc/testsuite/c-c++-common/musttail21.c
+@@ -1,4 +1,4 @@
+-/* { dg-do compile { target { c || c++11 } } } */
++/* { dg-do compile { target musttail } } */
+ void f(void)
+ {
+   __attribute__((musttail)) return; /* { dg-error "cannot tail-call.*return value must be a call" } */
+diff --git a/gcc/testsuite/c-c++-common/musttail28.c b/gcc/testsuite/c-c++-common/musttail28.c
+new file mode 100644
+index 000000000000..d84658aa8a05
+--- /dev/null
++++ b/gcc/testsuite/c-c++-common/musttail28.c
+@@ -0,0 +1,108 @@
++/* { dg-do compile { target { musttail && { c || c++11 } } } } */
++
++int foo (int, void *);
++int bar (int, int *);
++struct S { int a, b, c; };
++struct T { int d; struct S e; };
++
++int
++baz (int x, void *y)
++{
++  [[gnu::musttail]] return bar (2, &x);		/* { dg-warning "address of parameter 'x' passed to 'musttail' call argument" } */
++}
++
++int
++qux (int x, void *y)
++{
++  __label__ lab;
++  lab:;
++  if (*(int *) y == 1)
++    [[gnu::musttail]] return foo (1, &&lab);	/* { dg-warning "address of label passed to 'musttail' call argument" } */
++  if (x == 1)
++    [[gnu::musttail]] return foo (3, 0);
++  else if (x == 2)
++    {
++      {
++        int a = 42;
++        bar (4, &a);
++      }
++      [[gnu::musttail]] return bar (5, 0);
++    }
++  else if (x == 3)
++    {
++      int a = 42;
++      bar (4, &a);
++      [[gnu::musttail]] return bar (6, 0);
++    }
++  else if (x == 4)
++    {
++      int a = 42;
++      [[gnu::musttail]] return bar (7, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
++    }
++  else if (x == 5)
++    {
++      struct T b;
++      [[gnu::musttail]] return bar (8, &b.e.b);	/* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
++    }
++  else if (x == 6)
++    {
++      struct T b;
++      bar (9, &b.e.a);
++      [[gnu::musttail]] return bar (10, 0);
++    }
++  else if (x == 7)
++    {
++      {
++        struct T b;
++        bar (9, &b.e.a);
++      }
++      [[gnu::musttail]] return bar (11, 0);
++    }
++  else if (x == 8)
++    {
++      {
++        int a = 42;
++        bar (4, &a);
++      }
++      [[gnu::musttail]] return foo (12, 0);
++    }
++  else if (x == 9)
++    {
++      int a = 42;
++      bar (4, &a);
++      [[gnu::musttail]] return foo (13, 0);
++    }
++  else if (x == 10)
++    {
++      int a = 42;
++      [[gnu::musttail]] return foo (14, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
++    }
++  else if (x == 11)
++    {
++      struct T b;
++      [[gnu::musttail]] return foo (15, &b.e.b); /* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
++    }
++  else if (x == 12)
++    {
++      struct T b;
++      bar (9, &b.e.a);
++      [[gnu::musttail]] return foo (16, 0);
++    }
++  else if (x == 13)
++    {
++      {
++        struct T b;
++        bar (9, &b.e.a);
++      }
++      [[gnu::musttail]] return foo (17, 0);
++    }
++  return 0;
++}
++
++int
++corge (int x, void *y)
++{
++  if (*(int *) y == 1)
++    bar (18, &x);
++  [[gnu::musttail]] return bar (2, 0);
++}
+diff --git a/gcc/testsuite/c-c++-common/musttail29.c b/gcc/testsuite/c-c++-common/musttail29.c
+new file mode 100644
+index 000000000000..f6b3d76abe11
+--- /dev/null
++++ b/gcc/testsuite/c-c++-common/musttail29.c
+@@ -0,0 +1,109 @@
++/* { dg-do compile { target { musttail && { c || c++11 } } } } */
++/* { dg-options "-O2 -Wmusttail-local-addr" } */
++
++int foo (int, void *);
++int bar (int, int *);
++struct S { int a, b, c; };
++struct T { int d; struct S e; };
++
++int
++baz (int x, void *y)
++{
++  [[gnu::musttail]] return bar (2, &x);		/* { dg-warning "address of parameter 'x' passed to 'musttail' call argument" } */
++}
++
++int
++qux (int x, void *y)
++{
++  __label__ lab;
++  lab:;
++  if (*(int *) y == 1)
++    [[gnu::musttail]] return foo (1, &&lab);	/* { dg-warning "address of label passed to 'musttail' call argument" } */
++  if (x == 1)
++    [[gnu::musttail]] return foo (3, 0);
++  else if (x == 2)
++    {
++      {
++        int a = 42;
++        bar (4, &a);
++      }
++      [[gnu::musttail]] return bar (5, 0);
++    }
++  else if (x == 3)
++    {
++      int a = 42;
++      bar (4, &a);
++      [[gnu::musttail]] return bar (6, 0);
++    }
++  else if (x == 4)
++    {
++      int a = 42;
++      [[gnu::musttail]] return bar (7, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
++    }
++  else if (x == 5)
++    {
++      struct T b;
++      [[gnu::musttail]] return bar (8, &b.e.b);	/* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
++    }
++  else if (x == 6)
++    {
++      struct T b;
++      bar (9, &b.e.a);
++      [[gnu::musttail]] return bar (10, 0);
++    }
++  else if (x == 7)
++    {
++      {
++        struct T b;
++        bar (9, &b.e.a);
++      }
++      [[gnu::musttail]] return bar (11, 0);
++    }
++  else if (x == 8)
++    {
++      {
++        int a = 42;
++        bar (4, &a);
++      }
++      [[gnu::musttail]] return foo (12, 0);
++    }
++  else if (x == 9)
++    {
++      int a = 42;
++      bar (4, &a);
++      [[gnu::musttail]] return foo (13, 0);
++    }
++  else if (x == 10)
++    {
++      int a = 42;
++      [[gnu::musttail]] return foo (14, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
++    }
++  else if (x == 11)
++    {
++      struct T b;
++      [[gnu::musttail]] return foo (15, &b.e.b); /* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
++    }
++  else if (x == 12)
++    {
++      struct T b;
++      bar (9, &b.e.a);
++      [[gnu::musttail]] return foo (16, 0);
++    }
++  else if (x == 13)
++    {
++      {
++        struct T b;
++        bar (9, &b.e.a);
++      }
++      [[gnu::musttail]] return foo (17, 0);
++    }
++  return 0;
++}
++
++int
++corge (int x, void *y)
++{
++  if (*(int *) y == 1)
++    bar (18, &x);
++  [[gnu::musttail]] return bar (2, 0);
++}
+diff --git a/gcc/testsuite/c-c++-common/musttail30.c b/gcc/testsuite/c-c++-common/musttail30.c
+new file mode 100644
+index 000000000000..be1c3daf6af2
+--- /dev/null
++++ b/gcc/testsuite/c-c++-common/musttail30.c
+@@ -0,0 +1,109 @@
++/* { dg-do compile { target { musttail && { c || c++11 } } } } */
++/* { dg-options "-Wextra" } */
++
++int foo (int, void *);
++int bar (int, int *);
++struct S { int a, b, c; };
++struct T { int d; struct S e; };
++
++int
++baz (int x, void *y)
++{
++  [[gnu::musttail]] return bar (2, &x);		/* { dg-warning "address of parameter 'x' passed to 'musttail' call argument" } */
++}
++
++int
++qux (int x, void *y)
++{
++  __label__ lab;
++  lab:;
++  if (*(int *) y == 1)
++    [[gnu::musttail]] return foo (1, &&lab);	/* { dg-warning "address of label passed to 'musttail' call argument" } */
++  if (x == 1)
++    [[gnu::musttail]] return foo (3, 0);
++  else if (x == 2)
++    {
++      {
++        int a = 42;
++        bar (4, &a);
++      }
++      [[gnu::musttail]] return bar (5, 0);
++    }
++  else if (x == 3)
++    {
++      int a = 42;
++      bar (4, &a);
++      [[gnu::musttail]] return bar (6, 0);	/* { dg-warning "address of automatic variable 'a' can escape to 'musttail' call" } */
++    }
++  else if (x == 4)
++    {
++      int a = 42;
++      [[gnu::musttail]] return bar (7, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
++    }
++  else if (x == 5)
++    {
++      struct T b;
++      [[gnu::musttail]] return bar (8, &b.e.b);	/* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
++    }
++  else if (x == 6)
++    {
++      struct T b;
++      bar (9, &b.e.a);
++      [[gnu::musttail]] return bar (10, 0);	/* { dg-warning "address of automatic variable 'b' can escape to 'musttail' call" } */
++    }
++  else if (x == 7)
++    {
++      {
++        struct T b;
++        bar (9, &b.e.a);
++      }
++      [[gnu::musttail]] return bar (11, 0);
++    }
++  else if (x == 8)
++    {
++      {
++        int a = 42;
++        bar (4, &a);
++      }
++      [[gnu::musttail]] return foo (12, 0);
++    }
++  else if (x == 9)
++    {
++      int a = 42;
++      bar (4, &a);
++      [[gnu::musttail]] return foo (13, 0);	/* { dg-warning "address of automatic variable 'a' can escape to 'musttail' call" } */
++    }
++  else if (x == 10)
++    {
++      int a = 42;
++      [[gnu::musttail]] return foo (14, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
++    }
++  else if (x == 11)
++    {
++      struct T b;
++      [[gnu::musttail]] return foo (15, &b.e.b); /* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
++    }
++  else if (x == 12)
++    {
++      struct T b;
++      bar (9, &b.e.a);
++      [[gnu::musttail]] return foo (16, 0);	/* { dg-warning "address of automatic variable 'b' can escape to 'musttail' call" } */
++    }
++  else if (x == 13)
++    {
++      {
++        struct T b;
++        bar (9, &b.e.a);
++      }
++      [[gnu::musttail]] return foo (17, 0);
++    }
++  return 0;
++}
++
++int
++corge (int x, void *y)
++{
++  if (*(int *) y == 1)
++    bar (18, &x);
++  [[gnu::musttail]] return bar (2, 0);		/* { dg-warning "address of parameter 'x' can escape to 'musttail' call" } */
++}
+diff --git a/gcc/testsuite/c-c++-common/musttail31.c b/gcc/testsuite/c-c++-common/musttail31.c
+new file mode 100644
+index 000000000000..f44ada4d4733
+--- /dev/null
++++ b/gcc/testsuite/c-c++-common/musttail31.c
+@@ -0,0 +1,109 @@
++/* { dg-do compile { target { musttail && { c || c++11 } } } } */
++/* { dg-options "-O2 -Wmaybe-musttail-local-addr" } */
++
++int foo (int, void *);
++int bar (int, int *);
++struct S { int a, b, c; };
++struct T { int d; struct S e; };
++
++int
++baz (int x, void *y)
++{
++  [[gnu::musttail]] return bar (2, &x);		/* { dg-warning "address of parameter 'x' passed to 'musttail' call argument" } */
++}
++
++int
++qux (int x, void *y)
++{
++  __label__ lab;
++  lab:;
++  if (*(int *) y == 1)
++    [[gnu::musttail]] return foo (1, &&lab);	/* { dg-warning "address of label passed to 'musttail' call argument" } */
++  if (x == 1)
++    [[gnu::musttail]] return foo (3, 0);
++  else if (x == 2)
++    {
++      {
++        int a = 42;
++        bar (4, &a);
++      }
++      [[gnu::musttail]] return bar (5, 0);
++    }
++  else if (x == 3)
++    {
++      int a = 42;
++      bar (4, &a);
++      [[gnu::musttail]] return bar (6, 0);	/* { dg-warning "address of automatic variable 'a' can escape to 'musttail' call" } */
++    }
++  else if (x == 4)
++    {
++      int a = 42;
++      [[gnu::musttail]] return bar (7, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
++    }
++  else if (x == 5)
++    {
++      struct T b;
++      [[gnu::musttail]] return bar (8, &b.e.b);	/* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
++    }
++  else if (x == 6)
++    {
++      struct T b;
++      bar (9, &b.e.a);
++      [[gnu::musttail]] return bar (10, 0);	/* { dg-warning "address of automatic variable 'b' can escape to 'musttail' call" } */
++    }
++  else if (x == 7)
++    {
++      {
++        struct T b;
++        bar (9, &b.e.a);
++      }
++      [[gnu::musttail]] return bar (11, 0);
++    }
++  else if (x == 8)
++    {
++      {
++        int a = 42;
++        bar (4, &a);
++      }
++      [[gnu::musttail]] return foo (12, 0);
++    }
++  else if (x == 9)
++    {
++      int a = 42;
++      bar (4, &a);
++      [[gnu::musttail]] return foo (13, 0);	/* { dg-warning "address of automatic variable 'a' can escape to 'musttail' call" } */
++    }
++  else if (x == 10)
++    {
++      int a = 42;
++      [[gnu::musttail]] return foo (14, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
++    }
++  else if (x == 11)
++    {
++      struct T b;
++      [[gnu::musttail]] return foo (15, &b.e.b); /* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
++    }
++  else if (x == 12)
++    {
++      struct T b;
++      bar (9, &b.e.a);
++      [[gnu::musttail]] return foo (16, 0);	/* { dg-warning "address of automatic variable 'b' can escape to 'musttail' call" } */
++    }
++  else if (x == 13)
++    {
++      {
++        struct T b;
++        bar (9, &b.e.a);
++      }
++      [[gnu::musttail]] return foo (17, 0);
++    }
++  return 0;
++}
++
++int
++corge (int x, void *y)
++{
++  if (*(int *) y == 1)
++    bar (18, &x);
++  [[gnu::musttail]] return bar (2, 0);		/* { dg-warning "address of parameter 'x' can escape to 'musttail' call" } */
++}
+diff --git a/gcc/testsuite/c-c++-common/musttail8.c b/gcc/testsuite/c-c++-common/musttail8.c
+index 50ca1ac0dd48..9a29030a3b06 100644
+--- a/gcc/testsuite/c-c++-common/musttail8.c
++++ b/gcc/testsuite/c-c++-common/musttail8.c
+@@ -10,8 +10,9 @@ int f2(void)
+ 
+ int f3(int *);
+ 
+-int f4(void)
++int f4(int *p)
+ {
+   int x;
+-  [[gnu::musttail]] return f3(&x); /* { dg-error "\(refers to locals|other reasons\)" } */
++  (void) p;
++  [[gnu::musttail]] return f3(&x); /* { dg-warning "address of automatic variable 'x' passed to 'musttail' call argument" } */
+ }
+diff --git a/gcc/testsuite/g++.dg/ext/musttail1.C b/gcc/testsuite/g++.dg/ext/musttail1.C
+new file mode 100644
+index 000000000000..fd9b386a5974
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/ext/musttail1.C
+@@ -0,0 +1,38 @@
++// PR ipa/119376
++// { dg-do compile { target { musttail && c++11 } } }
++// { dg-options "-Wmaybe-musttail-local-addr" }
++
++int foo (int &);
++int bar (int &&);
++int corge (int *);
++
++int
++baz (int &x)
++{
++  if (x == 1)
++    [[gnu::musttail]] return foo (x);
++  if (x == 2)
++    {
++      int a = 42;
++      [[gnu::musttail]] return foo (a);		// { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" }
++    }
++  if (x == 3)
++    {
++      int a = 42;
++      foo (a);
++      [[gnu::musttail]] return foo (x);		// { dg-warning "address of automatic variable 'a' can escape to 'musttail' call" }
++    }
++  return 0;
++}
++
++int
++qux (int &&x)
++{
++  [[gnu::musttail]] return bar (x + 1);		// { dg-warning "address of local variable passed to 'musttail' call argument" }
++}
++
++int
++freddy (int x)
++{
++  [[gnu::musttail]] return foo (x);		// { dg-warning "address of parameter 'x' passed to 'musttail' call argument" }
++}
+diff --git a/gcc/testsuite/g++.dg/ext/musttail2.C b/gcc/testsuite/g++.dg/ext/musttail2.C
+new file mode 100644
+index 000000000000..ac99aafb0f0c
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/ext/musttail2.C
+@@ -0,0 +1,38 @@
++// PR ipa/119376
++// { dg-do compile { target { musttail && c++11 } } }
++// { dg-options "-Wextra" }
++
++int foo (int &);
++int bar (int &&);
++int corge (int *);
++
++int
++baz (int &x)
++{
++  if (x == 1)
++    [[clang::musttail]] return foo (x);
++  if (x == 2)
++    {
++      int a = 42;
++      [[clang::musttail]] return foo (a);		// { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" }
++    }
++  if (x == 3)
++    {
++      int a = 42;
++      foo (a);
++      [[clang::musttail]] return foo (x);		// { dg-warning "address of automatic variable 'a' can escape to 'musttail' call" }
++    }
++  return 0;
++}
++
++int
++qux (int &&x)
++{
++  [[clang::musttail]] return bar (x + 1);		// { dg-warning "address of local variable passed to 'musttail' call argument" }
++}
++
++int
++freddy (int x)
++{
++  [[clang::musttail]] return foo (x);			// { dg-warning "address of parameter 'x' passed to 'musttail' call argument" }
++}
+diff --git a/gcc/testsuite/g++.dg/ext/musttail3.C b/gcc/testsuite/g++.dg/ext/musttail3.C
+new file mode 100644
+index 000000000000..1c4b939a2a43
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/ext/musttail3.C
+@@ -0,0 +1,37 @@
++// PR ipa/119376
++// { dg-do compile { target { musttail && c++11 } } }
++
++int foo (int &);
++int bar (int &&);
++int corge (int *);
++
++int
++baz (int &x)
++{
++  if (x == 1)
++    [[gnu::musttail]] return foo (x);
++  if (x == 2)
++    {
++      int a = 42;
++      [[gnu::musttail]] return foo (a);		// { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" }
++    }
++  if (x == 3)
++    {
++      int a = 42;
++      foo (a);
++      [[gnu::musttail]] return foo (x);
++    }
++  return 0;
++}
++
++int
++qux (int &&x)
++{
++  [[gnu::musttail]] return bar (x + 1);		// { dg-warning "address of local variable passed to 'musttail' call argument" }
++}
++
++int
++freddy (int x)
++{
++  [[gnu::musttail]] return foo (x);		// { dg-warning "address of parameter 'x' passed to 'musttail' call argument" }
++}
+diff --git a/gcc/tree-tailcall.cc b/gcc/tree-tailcall.cc
+index 8ba675221915..e025a1cb78b2 100644
+--- a/gcc/tree-tailcall.cc
++++ b/gcc/tree-tailcall.cc
+@@ -206,14 +206,48 @@ suitable_for_tail_call_opt_p (gcall *call, bool diag_musttail)
+ 
+   /* ??? It is OK if the argument of a function is taken in some cases,
+      but not in all cases.  See PR15387 and PR19616.  Revisit for 4.1.  */
+-  for (param = DECL_ARGUMENTS (current_function_decl);
+-       param;
+-       param = DECL_CHAIN (param))
+-    if (TREE_ADDRESSABLE (param))
++  if (!diag_musttail || !gimple_call_must_tail_p (call))
++    for (param = DECL_ARGUMENTS (current_function_decl);
++	 param; param = DECL_CHAIN (param))
++      if (TREE_ADDRESSABLE (param))
++	{
++	  maybe_error_musttail (call, _("address of caller arguments taken"),
++				diag_musttail);
++	  return false;
++	}
++
++  if (diag_musttail
++      && gimple_call_must_tail_p (call)
++      && warn_musttail_local_addr)
++    for (unsigned int i = 0; i < gimple_call_num_args (call); i++)
+       {
+-	maybe_error_musttail (call, _("address of caller arguments taken"),
+-			      diag_musttail);
+-	return false;
++	tree arg = gimple_call_arg (call, i);
++	if (!POINTER_TYPE_P (TREE_TYPE (arg)))
++	  continue;
++	if (TREE_CODE (arg) == ADDR_EXPR)
++	  {
++	    arg = get_base_address (TREE_OPERAND (arg, 0));
++	    if (auto_var_in_fn_p (arg, current_function_decl))
++	      {
++		if (TREE_CODE (arg) == LABEL_DECL)
++		  warning_at (gimple_location (call), OPT_Wmusttail_local_addr,
++			      "address of label passed to %<musttail%> "
++			      "call argument");
++		else if (TREE_CODE (arg) == PARM_DECL)
++		  warning_at (gimple_location (call), OPT_Wmusttail_local_addr,
++			      "address of parameter %qD passed to "
++			      "%<musttail%> call argument", arg);
++		else if (!DECL_ARTIFICIAL (arg) && DECL_NAME (arg))
++		  warning_at (gimple_location (call), OPT_Wmusttail_local_addr,
++			      "address of automatic variable %qD passed to "
++			      "%<musttail%> call argument", arg);
++		else
++		  warning_at (gimple_location (call), OPT_Wmusttail_local_addr,
++			      "address of local variable passed to "
++			      "%<musttail%> call argument");
++		suppress_warning (call, OPT_Wmaybe_musttail_local_addr);
++	      }
++	  }
+       }
+ 
+   return true;
+@@ -443,7 +477,7 @@ maybe_error_musttail (gcall *call, const char *err, bool diag_musttail)
+ {
+   if (gimple_call_must_tail_p (call) && diag_musttail)
+     {
+-      error_at (call->location, "cannot tail-call: %s", err);
++      error_at (gimple_location (call), "cannot tail-call: %s", err);
+       /* Avoid another error. ??? If there are multiple reasons why tail
+ 	 calls fail it might be useful to report them all to avoid
+ 	 whack-a-mole for the user. But currently there is too much
+@@ -728,6 +762,19 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
+ 	{
+ 	  if (!VAR_P (var))
+ 	    {
++	      if (diag_musttail && gimple_call_must_tail_p (call))
++		{
++		  auto opt = OPT_Wmaybe_musttail_local_addr;
++		  if (!warning_suppressed_p (call,
++					     opt))
++		    {
++		      warning_at (gimple_location (call), opt,
++				  "address of local variable can escape to "
++				  "%<musttail%> call");
++		      suppress_warning (call, opt);
++		    }
++		  continue;
++		}
+ 	      if (local_live_vars)
+ 		BITMAP_FREE (local_live_vars);
+ 	      maybe_error_musttail (call,
+@@ -740,6 +787,24 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
+ 	      unsigned int *v = live_vars->get (DECL_UID (var));
+ 	      if (bitmap_bit_p (local_live_vars, *v))
+ 		{
++		  if (diag_musttail && gimple_call_must_tail_p (call))
++		    {
++		      auto opt = OPT_Wmaybe_musttail_local_addr;
++		      if (!warning_suppressed_p (call, opt))
++			{
++			  if (!DECL_ARTIFICIAL (var) && DECL_NAME (var))
++			    warning_at (gimple_location (call), opt,
++					"address of automatic variable %qD "
++					"can escape to %<musttail%> call",
++					var);
++			  else
++			    warning_at (gimple_location (call), opt,
++					"address of local variable can escape "
++					"to %<musttail%> call");
++			  suppress_warning (call, opt);
++			}
++		      continue;
++		    }
+ 		  BITMAP_FREE (local_live_vars);
+ 		  maybe_error_musttail (call,
+ 					_("call invocation refers to locals"),
+@@ -749,6 +814,22 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
+ 	    }
+ 	}
+     }
++  if (diag_musttail
++      && gimple_call_must_tail_p (call)
++      && !warning_suppressed_p (call, OPT_Wmaybe_musttail_local_addr))
++    for (tree param = DECL_ARGUMENTS (current_function_decl);
++	 param; param = DECL_CHAIN (param))
++      if (may_be_aliased (param)
++	  && (ref_maybe_used_by_stmt_p (call, param, false)
++	      || call_may_clobber_ref_p (call, param, false)))
++	{
++	  auto opt = OPT_Wmaybe_musttail_local_addr;
++	  warning_at (gimple_location (call), opt,
++		      "address of parameter %qD can escape to "
++		      "%<musttail%> call", param);
++	  suppress_warning (call, opt);
++	  break;
++	}
+ 
+   if (local_live_vars)
+     BITMAP_FREE (local_live_vars);
+
+base-commit: eb26b667518c951d06f3c51118a1d41dcdda8b99
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 70acf07..73d7ea2 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -3,6 +3,7 @@
 	+ 35_all_checking-gc-use-heuristics.patch
 	+ 78_all_PR119291-combine-Use-reg_used_between_p-rather-than-modified_.patch
 	+ 79_all_PR119291-combine-Special-case-set_noop_p-in-two-spots.patch
+	+ 80_all_PR119376-tailc-Don-t-fail-musttail-calls-if-they-use-or-could.patch
 
 49	26 March 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-31  4:05 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-31  4:05 UTC (permalink / raw
  To: gentoo-commits
commit:     2090b16938d5390ededff31412455e63ed007ab7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 31 03:59:16 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Mar 31 03:59:16 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=2090b169
15.0.0: cut patchset 50
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 73d7ea2..88fe306 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-50	????
+50	31 March 2025
 
 	+ 35_all_checking-gc-use-heuristics.patch
 	+ 78_all_PR119291-combine-Use-reg_used_between_p-rather-than-modified_.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-31 22:03 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-31 22:03 UTC (permalink / raw
  To: gentoo-commits
commit:     0f42333c225b04ca215276ee4edae596a8000708
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 31 22:03:32 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Mar 31 22:03:53 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=0f42333c
15.0.0: add 81_all_PR119383-missing-lifetime-extension.patch
Fixes Boost.
Bug: https://gcc.gnu.org/PR119383
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...1_all_PR119383-missing-lifetime-extension.patch | 166 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   4 +
 2 files changed, 170 insertions(+)
diff --git a/15.0.0/gentoo/81_all_PR119383-missing-lifetime-extension.patch b/15.0.0/gentoo/81_all_PR119383-missing-lifetime-extension.patch
new file mode 100644
index 0000000..ff534d7
--- /dev/null
+++ b/15.0.0/gentoo/81_all_PR119383-missing-lifetime-extension.patch
@@ -0,0 +1,166 @@
+From d1ddf83b25fbe6c7c247007c754b7858cfaea916 Mon Sep 17 00:00:00 2001
+Message-ID: <d1ddf83b25fbe6c7c247007c754b7858cfaea916.1743458566.git.sam@gentoo.org>
+From: Marek Polacek <polacek@redhat.com>
+Date: Mon, 31 Mar 2025 16:59:08 -0400
+Subject: [PATCH] c++: fix missing lifetime extension [PR119383]
+
+Since r15-8011 cp_build_indirect_ref_1 won't do the *&TARGET_EXPR ->
+TARGET_EXPR folding not to change its value category.  That fix seems
+correct but it made us stop extending the lifetime in this testcase,
+causing a wrong-code issue -- extend_ref_init_temps_1 did not see
+through the extra *& because it doesn't use a tree walk.
+
+This patch reverts r15-8011 and instead handles the problem in
+build_over_call by calling force_lvalue in the is_really_empty_class
+case as well as in the general case.
+
+	PR c++/119383
+
+gcc/cp/ChangeLog:
+
+	* call.cc (build_over_call): Use force_lvalue to ensure op= returns
+	an lvalue.
+	* cp-tree.h (force_lvalue): Declare.
+	* cvt.cc (force_lvalue): New.
+	* typeck.cc (cp_build_indirect_ref_1): Revert r15-8011.
+
+gcc/testsuite/ChangeLog:
+
+* g++.dg/cpp0x/temp-extend3.C: New test.
+---
+ gcc/cp/call.cc                            |  9 ++++---
+ gcc/cp/cp-tree.h                          |  1 +
+ gcc/cp/cvt.cc                             | 13 +++++++++
+ gcc/cp/typeck.cc                          | 10 +++----
+ gcc/testsuite/g++.dg/cpp0x/temp-extend3.C | 32 +++++++++++++++++++++++
+ 5 files changed, 55 insertions(+), 10 deletions(-)
+ create mode 100644 gcc/testsuite/g++.dg/cpp0x/temp-extend3.C
+
+diff --git a/gcc/cp/call.cc b/gcc/cp/call.cc
+index c1c8987ec8b1..b1469cb5a4c9 100644
+--- a/gcc/cp/call.cc
++++ b/gcc/cp/call.cc
+@@ -10828,10 +10828,8 @@ build_over_call (struct z_candidate *cand, int flags, tsubst_flags_t complain)
+       if (is_really_empty_class (type, /*ignore_vptr*/true))
+ 	{
+ 	  /* Avoid copying empty classes, but ensure op= returns an lvalue even
+-	     if the object argument isn't one. This isn't needed in other cases
+-	     since MODIFY_EXPR is always considered an lvalue.  */
+-	  to = cp_build_addr_expr (to, tf_none);
+-	  to = cp_build_indirect_ref (input_location, to, RO_ARROW, complain);
++	     if the object argument isn't one.  */
++	  to = force_lvalue (to, complain);
+ 	  val = build2 (COMPOUND_EXPR, type, arg, to);
+ 	  suppress_warning (val, OPT_Wunused);
+ 	}
+@@ -10852,6 +10850,9 @@ build_over_call (struct z_candidate *cand, int flags, tsubst_flags_t complain)
+ 	  tree array_type, alias_set;
+ 
+ 	  arg2 = TYPE_SIZE_UNIT (as_base);
++	  /* Ensure op= returns an lvalue even if the object argument isn't
++	     one.  */
++	  to = force_lvalue (to, complain);
+ 	  to = cp_stabilize_reference (to);
+ 	  arg0 = cp_build_addr_expr (to, complain);
+ 
+diff --git a/gcc/cp/cp-tree.h b/gcc/cp/cp-tree.h
+index 2f2122dcf241..927f51b116b3 100644
+--- a/gcc/cp/cp-tree.h
++++ b/gcc/cp/cp-tree.h
+@@ -7079,6 +7079,7 @@ extern tree convert_to_reference		(tree, tree, int, int, tree,
+ 						 tsubst_flags_t);
+ extern tree convert_from_reference		(tree);
+ extern tree force_rvalue			(tree, tsubst_flags_t);
++extern tree force_lvalue			(tree, tsubst_flags_t);
+ extern tree ocp_convert				(tree, tree, int, int,
+ 						 tsubst_flags_t);
+ extern tree cp_convert				(tree, tree, tsubst_flags_t);
+diff --git a/gcc/cp/cvt.cc b/gcc/cp/cvt.cc
+index bd1f147f2c56..f663a6d08c89 100644
+--- a/gcc/cp/cvt.cc
++++ b/gcc/cp/cvt.cc
+@@ -575,6 +575,19 @@ force_rvalue (tree expr, tsubst_flags_t complain)
+   return expr;
+ }
+ 
++/* Force EXPR to be an lvalue, if it isn't already.  */
++
++tree
++force_lvalue (tree expr, tsubst_flags_t complain)
++{
++  if (!lvalue_p (expr))
++    {
++      expr = cp_build_addr_expr (expr, complain);
++      expr = cp_build_indirect_ref (input_location, expr, RO_ARROW, complain);
++    }
++  return expr;
++}
++
+ \f
+ /* If EXPR and ORIG are INTEGER_CSTs, return a version of EXPR that has
+    TREE_OVERFLOW set only if it is set in ORIG.  Otherwise, return EXPR
+diff --git a/gcc/cp/typeck.cc b/gcc/cp/typeck.cc
+index c8e4441fb8b4..4f4dc683b5a0 100644
+--- a/gcc/cp/typeck.cc
++++ b/gcc/cp/typeck.cc
+@@ -3870,13 +3870,11 @@ cp_build_indirect_ref_1 (location_t loc, tree ptr, ref_operator errorstring,
+ 	  return error_mark_node;
+ 	}
+       else if (do_fold && TREE_CODE (pointer) == ADDR_EXPR
+-	       && same_type_p (t, TREE_TYPE (TREE_OPERAND (pointer, 0)))
+-	       /* Don't let this change the value category.  '*&TARGET_EXPR'
+-		  is an lvalue, but folding it into 'TARGET_EXPR' would turn
+-		  it into a prvalue of class type.  */
+-	       && lvalue_p (TREE_OPERAND (pointer, 0)))
++	       && same_type_p (t, TREE_TYPE (TREE_OPERAND (pointer, 0))))
+ 	/* The POINTER was something like `&x'.  We simplify `*&x' to
+-	   `x'.  */
++	   `x'.  This change the value category: '*&TARGET_EXPR'
++	   is an lvalue and folding it into 'TARGET_EXPR' turns it into
++	   a prvalue of class type.  */
+ 	return TREE_OPERAND (pointer, 0);
+       else
+ 	{
+diff --git a/gcc/testsuite/g++.dg/cpp0x/temp-extend3.C b/gcc/testsuite/g++.dg/cpp0x/temp-extend3.C
+new file mode 100644
+index 000000000000..3eab88d0076e
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/cpp0x/temp-extend3.C
+@@ -0,0 +1,32 @@
++// PR c++/119383
++// { dg-do run { target c++11 } }
++
++int g;
++
++struct base {
++  virtual base *clone() const = 0;
++  ~base() { }
++};
++
++struct impl : virtual base {
++  base *clone() const { return new impl; }  // #1
++  impl() { ++g; }
++  ~impl() { --g; }
++};
++
++const base *
++make_a_clone ()
++{
++  const base &base = impl{}; // #2
++  return base.clone();
++}
++
++int
++main ()
++{
++  make_a_clone ();
++  // impl::impl() is called twice (#1 and #2), impl::~impl() once,
++  // at the end of make_a_clone.
++  if (g != 1)
++    __builtin_abort ();
++}
+
+base-commit: aa3aaf2bfb8fcc17076993df4297597b68bc5f60
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 88fe306..e54ab8b 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+51	????
+
+	+ 81_all_PR119383-missing-lifetime-extension.patch
+
 50	31 March 2025
 
 	+ 35_all_checking-gc-use-heuristics.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-03-31 22:16 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-03-31 22:16 UTC (permalink / raw
  To: gentoo-commits
commit:     bf513bda9c29822dae7198066c2a6bb18fd2b65b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 31 22:15:53 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Mar 31 22:16:17 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=bf513bda
15.0.0: add another ipa-cp fix
Bug: https://gcc.gnu.org/PR119318
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...1_all_PR119383-missing-lifetime-extension.patch |   2 +
 15.0.0/gentoo/82_all_PR119318-ipa-cp.patch         | 168 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   1 +
 3 files changed, 171 insertions(+)
diff --git a/15.0.0/gentoo/81_all_PR119383-missing-lifetime-extension.patch b/15.0.0/gentoo/81_all_PR119383-missing-lifetime-extension.patch
index ff534d7..42eed3f 100644
--- a/15.0.0/gentoo/81_all_PR119383-missing-lifetime-extension.patch
+++ b/15.0.0/gentoo/81_all_PR119383-missing-lifetime-extension.patch
@@ -1,3 +1,5 @@
+https://inbox.sourceware.org/gcc-patches/Z-sCHDjucrcWTs2f@redhat.com/
+
 From d1ddf83b25fbe6c7c247007c754b7858cfaea916 Mon Sep 17 00:00:00 2001
 Message-ID: <d1ddf83b25fbe6c7c247007c754b7858cfaea916.1743458566.git.sam@gentoo.org>
 From: Marek Polacek <polacek@redhat.com>
diff --git a/15.0.0/gentoo/82_all_PR119318-ipa-cp.patch b/15.0.0/gentoo/82_all_PR119318-ipa-cp.patch
new file mode 100644
index 0000000..895e25e
--- /dev/null
+++ b/15.0.0/gentoo/82_all_PR119318-ipa-cp.patch
@@ -0,0 +1,168 @@
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119318#c5
+
+Subject: [PATCH] ipa-cp: Make propagation of bits in IPA-CP aware of type conversions (PR119318)
+
+After the propagation of constants and value ranges, it turns out
+that the propagation of known bits also needs to be made aware of any
+intermediate types in which any arithmetic operations are made and
+must limit its precision there.  This implements just that.
+
+Bootstrapped and tested on x86_64-linux.
+
+gcc/ChangeLog:
+
+2025-03-18  Martin Jambor  <mjambor@suse.cz>
+
+	PR ipa/119318
+	* ipa-cp.cc (ipcp_bits_lattice::meet_with_1): Set all mask bits
+	not covered by precision to one.
+	(ipcp_bits_lattice::meet_with): Likewise.
+	(propagate_bits_across_jump_function): Use the first operand type
+	rather than the final parameter one to perform meet with other
+	lattices.  Check the operation conforms with
+	expr_type_first_operand_type_p.
+	* tree.cc (expr_type_first_operand_type_p): Add POINTER_PLUS_EXPR.
+
+gcc/testsuite/ChangeLog:
+
+2025-03-18  Martin Jambor  <mjambor@suse.cz>
+
+	PR ipa/119318
+	* gcc.dg/ipa/pr119318.c: New test.
+---
+ gcc/ipa-cp.cc                       | 26 +++++++++++++++++---
+ gcc/testsuite/gcc.dg/ipa/pr119318.c | 38 +++++++++++++++++++++++++++++
+ gcc/tree.cc                         |  1 +
+ 3 files changed, 61 insertions(+), 4 deletions(-)
+ create mode 100644 gcc/testsuite/gcc.dg/ipa/pr119318.c
+
+diff --git a/gcc/ipa-cp.cc b/gcc/ipa-cp.cc
+index 264568989a9..eff20a9ac55 100644
+--- a/gcc/ipa-cp.cc
++++ b/gcc/ipa-cp.cc
+@@ -918,6 +918,8 @@ ipcp_bits_lattice::meet_with_1 (widest_int value, widest_int mask,
+     m_mask |= m_value;
+   m_value &= ~m_mask;
+ 
++  widest_int cap_mask = wi::bit_not (wi::sub (wi::lshift (1, precision), 1));
++  m_mask |= cap_mask;
+   if (wi::sext (m_mask, precision) == -1)
+     return set_to_bottom ();
+ 
+@@ -996,6 +998,8 @@ ipcp_bits_lattice::meet_with (ipcp_bits_lattice& other, unsigned precision,
+ 	  adjusted_mask |= adjusted_value;
+ 	  adjusted_value &= ~adjusted_mask;
+ 	}
++      widest_int cap_mask = wi::bit_not (wi::sub (wi::lshift (1, precision), 1));
++      adjusted_mask |= cap_mask;
+       if (wi::sext (adjusted_mask, precision) == -1)
+ 	return set_to_bottom ();
+       return set_to_constant (adjusted_value, adjusted_mask);
+@@ -2507,9 +2511,6 @@ propagate_bits_across_jump_function (cgraph_edge *cs, int idx,
+       return dest_lattice->set_to_bottom ();
+     }
+ 
+-  unsigned precision = TYPE_PRECISION (parm_type);
+-  signop sgn = TYPE_SIGN (parm_type);
+-
+   if (jfunc->type == IPA_JF_PASS_THROUGH
+       || jfunc->type == IPA_JF_ANCESTOR)
+     {
+@@ -2522,6 +2523,16 @@ propagate_bits_across_jump_function (cgraph_edge *cs, int idx,
+       if (jfunc->type == IPA_JF_PASS_THROUGH)
+ 	{
+ 	  code = ipa_get_jf_pass_through_operation (jfunc);
++	  if (code != NOP_EXPR
++	      && !expr_type_first_operand_type_p (code))
++	    {
++	      if (dump_file && (dump_flags & TDF_DETAILS))
++		fprintf (dump_file, "Setting dest_lattice to bottom, because "
++			 "the operation involved in computing param %i of %s "
++			 "does not preserve types.\n",
++		 idx, cs->callee->dump_name ());
++	      return dest_lattice->set_to_bottom ();
++	    }
+ 	  src_idx = ipa_get_jf_pass_through_formal_id (jfunc);
+ 	  if (code != NOP_EXPR)
+ 	    operand = ipa_get_jf_pass_through_operand (jfunc);
+@@ -2554,6 +2565,12 @@ propagate_bits_across_jump_function (cgraph_edge *cs, int idx,
+ 	  bool drop_all_ones
+ 	    = keep_null && !src_lats->bits_lattice.known_nonzero_p ();
+ 
++	  tree arg_type = ipa_get_type (caller_info, src_idx);
++	  if (!arg_type)
++	    return dest_lattice->set_to_bottom ();
++	  unsigned precision = TYPE_PRECISION (arg_type);
++	  signop sgn = TYPE_SIGN (arg_type);
++
+ 	  return dest_lattice->meet_with (src_lats->bits_lattice, precision,
+ 					  sgn, code, operand, drop_all_ones);
+ 	}
+@@ -2570,7 +2587,8 @@ propagate_bits_across_jump_function (cgraph_edge *cs, int idx,
+ 	    = widest_int::from (bm.mask (), TYPE_SIGN (parm_type));
+ 	  widest_int value
+ 	    = widest_int::from (bm.value (), TYPE_SIGN (parm_type));
+-	  return dest_lattice->meet_with (value, mask, precision);
++	  return dest_lattice->meet_with (value, mask,
++					  TYPE_PRECISION (parm_type));
+ 	}
+     }
+   return dest_lattice->set_to_bottom ();
+diff --git a/gcc/testsuite/gcc.dg/ipa/pr119318.c b/gcc/testsuite/gcc.dg/ipa/pr119318.c
+new file mode 100644
+index 00000000000..8e62ec5e350
+--- /dev/null
++++ b/gcc/testsuite/gcc.dg/ipa/pr119318.c
+@@ -0,0 +1,38 @@
++/* { dg-do run } */
++/* { dg-require-effective-target int128 } */
++/* { dg-additional-options "-Wno-psabi -w" } */
++/* { dg-options "-Wno-psabi -O2" } */
++
++typedef unsigned V __attribute__((vector_size (64)));
++typedef unsigned __int128 W __attribute__((vector_size (64)));
++
++W a;
++W b;
++W c = { -0xffff, -0xffff, -0xffff, -0xffff };
++
++static __attribute__((__noinline__, __noclone__)) W
++bar (unsigned __int128 u)
++{
++  return u + c;
++}
++
++static inline W
++foo (unsigned short s, V v)
++{
++  V y = (V) bar ((unsigned short) ~s);
++  v >>= y;
++  b ^= (W) a;
++  v *= v;
++  return (W) v + b;
++}
++
++
++int
++main ()
++{
++  W x = foo (0, (V) { 0, 5 });
++  for (unsigned i = 0; i < sizeof(x)/sizeof(x[0]); i++)
++    if (x[i] != (i ? 0 : 0x1900000000))
++      __builtin_abort();
++  return 0;
++}
+diff --git a/gcc/tree.cc b/gcc/tree.cc
+index eccfcc89da4..6a5d9d4d741 100644
+--- a/gcc/tree.cc
++++ b/gcc/tree.cc
+@@ -15051,6 +15051,7 @@ expr_type_first_operand_type_p (tree_code code)
+     case BIT_IOR_EXPR:
+     case BIT_XOR_EXPR:
+     case BIT_AND_EXPR:
++    case POINTER_PLUS_EXPR:
+ 
+     case LSHIFT_EXPR:
+     case RSHIFT_EXPR:
+-- 
+2.48.1
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index e54ab8b..0a6f844 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 51	????
 
 	+ 81_all_PR119383-missing-lifetime-extension.patch
+	+ 82_all_PR119318-ipa-cp.patch
 
 50	31 March 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-01 14:46 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-01 14:46 UTC (permalink / raw
  To: gentoo-commits
commit:     5a9abe3487663d97c3b2bc1bc5d6b5e59de514fe
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Apr  1 14:45:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr  1 14:45:08 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=5a9abe34
15.0.0: drop lifetime extension patch
Merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...1_all_PR119383-missing-lifetime-extension.patch | 168 ---------------------
 15.0.0/gentoo/README.history                       |   1 -
 2 files changed, 169 deletions(-)
diff --git a/15.0.0/gentoo/81_all_PR119383-missing-lifetime-extension.patch b/15.0.0/gentoo/81_all_PR119383-missing-lifetime-extension.patch
deleted file mode 100644
index 42eed3f..0000000
--- a/15.0.0/gentoo/81_all_PR119383-missing-lifetime-extension.patch
+++ /dev/null
@@ -1,168 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/Z-sCHDjucrcWTs2f@redhat.com/
-
-From d1ddf83b25fbe6c7c247007c754b7858cfaea916 Mon Sep 17 00:00:00 2001
-Message-ID: <d1ddf83b25fbe6c7c247007c754b7858cfaea916.1743458566.git.sam@gentoo.org>
-From: Marek Polacek <polacek@redhat.com>
-Date: Mon, 31 Mar 2025 16:59:08 -0400
-Subject: [PATCH] c++: fix missing lifetime extension [PR119383]
-
-Since r15-8011 cp_build_indirect_ref_1 won't do the *&TARGET_EXPR ->
-TARGET_EXPR folding not to change its value category.  That fix seems
-correct but it made us stop extending the lifetime in this testcase,
-causing a wrong-code issue -- extend_ref_init_temps_1 did not see
-through the extra *& because it doesn't use a tree walk.
-
-This patch reverts r15-8011 and instead handles the problem in
-build_over_call by calling force_lvalue in the is_really_empty_class
-case as well as in the general case.
-
-	PR c++/119383
-
-gcc/cp/ChangeLog:
-
-	* call.cc (build_over_call): Use force_lvalue to ensure op= returns
-	an lvalue.
-	* cp-tree.h (force_lvalue): Declare.
-	* cvt.cc (force_lvalue): New.
-	* typeck.cc (cp_build_indirect_ref_1): Revert r15-8011.
-
-gcc/testsuite/ChangeLog:
-
-* g++.dg/cpp0x/temp-extend3.C: New test.
----
- gcc/cp/call.cc                            |  9 ++++---
- gcc/cp/cp-tree.h                          |  1 +
- gcc/cp/cvt.cc                             | 13 +++++++++
- gcc/cp/typeck.cc                          | 10 +++----
- gcc/testsuite/g++.dg/cpp0x/temp-extend3.C | 32 +++++++++++++++++++++++
- 5 files changed, 55 insertions(+), 10 deletions(-)
- create mode 100644 gcc/testsuite/g++.dg/cpp0x/temp-extend3.C
-
-diff --git a/gcc/cp/call.cc b/gcc/cp/call.cc
-index c1c8987ec8b1..b1469cb5a4c9 100644
---- a/gcc/cp/call.cc
-+++ b/gcc/cp/call.cc
-@@ -10828,10 +10828,8 @@ build_over_call (struct z_candidate *cand, int flags, tsubst_flags_t complain)
-       if (is_really_empty_class (type, /*ignore_vptr*/true))
- 	{
- 	  /* Avoid copying empty classes, but ensure op= returns an lvalue even
--	     if the object argument isn't one. This isn't needed in other cases
--	     since MODIFY_EXPR is always considered an lvalue.  */
--	  to = cp_build_addr_expr (to, tf_none);
--	  to = cp_build_indirect_ref (input_location, to, RO_ARROW, complain);
-+	     if the object argument isn't one.  */
-+	  to = force_lvalue (to, complain);
- 	  val = build2 (COMPOUND_EXPR, type, arg, to);
- 	  suppress_warning (val, OPT_Wunused);
- 	}
-@@ -10852,6 +10850,9 @@ build_over_call (struct z_candidate *cand, int flags, tsubst_flags_t complain)
- 	  tree array_type, alias_set;
- 
- 	  arg2 = TYPE_SIZE_UNIT (as_base);
-+	  /* Ensure op= returns an lvalue even if the object argument isn't
-+	     one.  */
-+	  to = force_lvalue (to, complain);
- 	  to = cp_stabilize_reference (to);
- 	  arg0 = cp_build_addr_expr (to, complain);
- 
-diff --git a/gcc/cp/cp-tree.h b/gcc/cp/cp-tree.h
-index 2f2122dcf241..927f51b116b3 100644
---- a/gcc/cp/cp-tree.h
-+++ b/gcc/cp/cp-tree.h
-@@ -7079,6 +7079,7 @@ extern tree convert_to_reference		(tree, tree, int, int, tree,
- 						 tsubst_flags_t);
- extern tree convert_from_reference		(tree);
- extern tree force_rvalue			(tree, tsubst_flags_t);
-+extern tree force_lvalue			(tree, tsubst_flags_t);
- extern tree ocp_convert				(tree, tree, int, int,
- 						 tsubst_flags_t);
- extern tree cp_convert				(tree, tree, tsubst_flags_t);
-diff --git a/gcc/cp/cvt.cc b/gcc/cp/cvt.cc
-index bd1f147f2c56..f663a6d08c89 100644
---- a/gcc/cp/cvt.cc
-+++ b/gcc/cp/cvt.cc
-@@ -575,6 +575,19 @@ force_rvalue (tree expr, tsubst_flags_t complain)
-   return expr;
- }
- 
-+/* Force EXPR to be an lvalue, if it isn't already.  */
-+
-+tree
-+force_lvalue (tree expr, tsubst_flags_t complain)
-+{
-+  if (!lvalue_p (expr))
-+    {
-+      expr = cp_build_addr_expr (expr, complain);
-+      expr = cp_build_indirect_ref (input_location, expr, RO_ARROW, complain);
-+    }
-+  return expr;
-+}
-+
- \f
- /* If EXPR and ORIG are INTEGER_CSTs, return a version of EXPR that has
-    TREE_OVERFLOW set only if it is set in ORIG.  Otherwise, return EXPR
-diff --git a/gcc/cp/typeck.cc b/gcc/cp/typeck.cc
-index c8e4441fb8b4..4f4dc683b5a0 100644
---- a/gcc/cp/typeck.cc
-+++ b/gcc/cp/typeck.cc
-@@ -3870,13 +3870,11 @@ cp_build_indirect_ref_1 (location_t loc, tree ptr, ref_operator errorstring,
- 	  return error_mark_node;
- 	}
-       else if (do_fold && TREE_CODE (pointer) == ADDR_EXPR
--	       && same_type_p (t, TREE_TYPE (TREE_OPERAND (pointer, 0)))
--	       /* Don't let this change the value category.  '*&TARGET_EXPR'
--		  is an lvalue, but folding it into 'TARGET_EXPR' would turn
--		  it into a prvalue of class type.  */
--	       && lvalue_p (TREE_OPERAND (pointer, 0)))
-+	       && same_type_p (t, TREE_TYPE (TREE_OPERAND (pointer, 0))))
- 	/* The POINTER was something like `&x'.  We simplify `*&x' to
--	   `x'.  */
-+	   `x'.  This change the value category: '*&TARGET_EXPR'
-+	   is an lvalue and folding it into 'TARGET_EXPR' turns it into
-+	   a prvalue of class type.  */
- 	return TREE_OPERAND (pointer, 0);
-       else
- 	{
-diff --git a/gcc/testsuite/g++.dg/cpp0x/temp-extend3.C b/gcc/testsuite/g++.dg/cpp0x/temp-extend3.C
-new file mode 100644
-index 000000000000..3eab88d0076e
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/cpp0x/temp-extend3.C
-@@ -0,0 +1,32 @@
-+// PR c++/119383
-+// { dg-do run { target c++11 } }
-+
-+int g;
-+
-+struct base {
-+  virtual base *clone() const = 0;
-+  ~base() { }
-+};
-+
-+struct impl : virtual base {
-+  base *clone() const { return new impl; }  // #1
-+  impl() { ++g; }
-+  ~impl() { --g; }
-+};
-+
-+const base *
-+make_a_clone ()
-+{
-+  const base &base = impl{}; // #2
-+  return base.clone();
-+}
-+
-+int
-+main ()
-+{
-+  make_a_clone ();
-+  // impl::impl() is called twice (#1 and #2), impl::~impl() once,
-+  // at the end of make_a_clone.
-+  if (g != 1)
-+    __builtin_abort ();
-+}
-
-base-commit: aa3aaf2bfb8fcc17076993df4297597b68bc5f60
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 0a6f844..7e0990c 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,5 @@
 51	????
 
-	+ 81_all_PR119383-missing-lifetime-extension.patch
 	+ 82_all_PR119318-ipa-cp.patch
 
 50	31 March 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-01 14:46 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-01 14:46 UTC (permalink / raw
  To: gentoo-commits
commit:     414a7d1bc292ae359a6c392ff078383d8e69194d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Apr  1 14:45:36 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr  1 14:45:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=414a7d1b
15.0.0: drop combine patches
The first one has been merged upstream just now, the other might
be later.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-reg_used_between_p-rather-than-modified_.patch | 196 ---------------------
 ...bine-Special-case-set_noop_p-in-two-spots.patch |  96 ----------
 2 files changed, 292 deletions(-)
diff --git a/15.0.0/gentoo/78_all_PR119291-combine-Use-reg_used_between_p-rather-than-modified_.patch b/15.0.0/gentoo/78_all_PR119291-combine-Use-reg_used_between_p-rather-than-modified_.patch
deleted file mode 100644
index 3264869..0000000
--- a/15.0.0/gentoo/78_all_PR119291-combine-Use-reg_used_between_p-rather-than-modified_.patch
+++ /dev/null
@@ -1,196 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/Z+aDTloxATzkpTbQ@tucnak/
-
-From 8db4ff073981a554ab5b77f958fa4a333b981b30 Mon Sep 17 00:00:00 2001
-Message-ID: <8db4ff073981a554ab5b77f958fa4a333b981b30.1743258660.git.sam@gentoo.org>
-From: Jakub Jelinek <jakub@redhat.com>
-Date: Fri, 28 Mar 2025 12:09:02 +0100
-Subject: [PATCH 1/2] combine: Use reg_used_between_p rather than
- modified_between_p in two spots [PR119291]
-
-Hi!
-
-The following testcase is miscompiled on x86_64-linux at -O2 by the combiner.
-We have from earlier combinations
-(insn 22 21 23 4 (set (reg:SI 104 [ _7 ])
-        (const_int 0 [0])) "pr119291.c":25:15 96 {*movsi_internal}
-     (nil))
-(insn 23 22 24 4 (set (reg/v:SI 117 [ e ])
-        (reg/v:SI 116 [ e ])) 96 {*movsi_internal}
-     (expr_list:REG_DEAD (reg/v:SI 116 [ e ])
-        (nil)))
-(note 24 23 25 4 NOTE_INSN_DELETED)
-(insn 25 24 26 4 (parallel [
-            (set (reg:CCZ 17 flags)
-                (compare:CCZ (neg:SI (reg:SI 104 [ _7 ]))
-                    (const_int 0 [0])))
-            (set (reg/v:SI 116 [ e ])
-                (neg:SI (reg:SI 104 [ _7 ])))
-        ]) "pr119291.c":26:13 977 {*negsi_2}
-     (expr_list:REG_DEAD (reg:SI 104 [ _7 ])
-        (nil)))
-(note 26 25 27 4 NOTE_INSN_DELETED)
-(insn 27 26 28 4 (set (reg:DI 128 [ _9 ])
-        (ne:DI (reg:CCZ 17 flags)
-            (const_int 0 [0]))) "pr119291.c":26:13 1447 {*setcc_di_1}
-     (expr_list:REG_DEAD (reg:CCZ 17 flags)
-        (nil)))
-and try_combine is called on i3 25 and i2 22 (second time)
-and reach the hunk being patched with simplified i3
-(insn 25 24 26 4 (parallel [
-            (set (pc)
-                (pc))
-            (set (reg/v:SI 116 [ e ])
-                (const_int 0 [0]))
-        ]) "pr119291.c":28:13 977 {*negsi_2}
-     (expr_list:REG_DEAD (reg:SI 104 [ _7 ])
-        (nil)))
-and
-(insn 22 21 23 4 (set (reg:SI 104 [ _7 ])
-        (const_int 0 [0])) "pr119291.c":27:15 96 {*movsi_internal}
-     (nil))
-Now, the try_combine code there attempts to split two independent
-sets in newpat by moving one of them to i2.
-And among other tests it checks
-!modified_between_p (SET_DEST (set1), i2, i3)
-which is certainly needed, if there would be say
-(set (reg/v:SI 116 [ e ]) (const_int 42 [0x2a]))
-in between i2 and i3, we couldn't do that, as that set would overwrite
-the value set by set1 we want to move to the i2 position.
-But in this case pseudo 116 isn't set in between i2 and i3, but used
-(and additionally there is a REG_DEAD note for it).
-
-This is equally bad for the move, because while the i3 insn
-and later will see the pseudo value that we set, the insn in between
-which uses the value will see a different value from the one that
-it should see.
-
-As we don't check for that, in the end try_combine succeeds and
-changes the IL to:
-(insn 22 21 23 4 (set (reg/v:SI 116 [ e ])
-        (const_int 0 [0])) "pr119291.c":27:15 96 {*movsi_internal}
-     (nil))
-(insn 23 22 24 4 (set (reg/v:SI 117 [ e ])
-        (reg/v:SI 116 [ e ])) 96 {*movsi_internal}
-     (expr_list:REG_DEAD (reg/v:SI 116 [ e ])
-        (nil)))
-(note 24 23 25 4 NOTE_INSN_DELETED)
-(insn 25 24 26 4 (set (pc)
-        (pc)) "pr119291.c":28:13 2147483647 {NOOP_MOVE}
-     (nil))
-(note 26 25 27 4 NOTE_INSN_DELETED)
-(insn 27 26 28 4 (set (reg:DI 128 [ _9 ])
-        (const_int 0 [0])) "pr119291.c":28:13 95 {*movdi_internal}
-     (nil))
-(note, the i3 got turned into a nop and try_combine also modified insn 27).
-
-The following patch replaces the modified_between_p
-tests with reg_used_between_p, my understanding is that
-modified_between_p is a subset of reg_used_between_p, so one
-doesn't need both.
-
-Bootstrapped/regtested on x86_64-linux, i686-linux, aarch64-linux,
-powerpc64le-linux and s390x-linux, ok for trunk?
-
-Looking at this some more today, I think we should special case
-set_noop_p because that can be put into i2 (except for the JUMP_P
-violations), currently both modified_between_p (pc_rtx, i2, i3)
-and reg_used_between_p (pc_rtx, i2, i3) returns false.
-I'll post a patch incrementally for that (but that feels like
-new optimization, so probably not something that should be backported).
-
-2025-03-28  Jakub Jelinek  <jakub@redhat.com>
-
-	PR rtl-optimization/119291
-	* combine.cc (try_combine): For splitting of PARALLEL with
-	2 independent SETs into i2 and i3 sets check reg_used_between_p
-	of the SET_DESTs rather than just modified_between_p.
-
-	* gcc.c-torture/execute/pr119291.c: New test.
----
- gcc/combine.cc                                | 14 ++++----
- .../gcc.c-torture/execute/pr119291.c          | 33 +++++++++++++++++++
- 2 files changed, 40 insertions(+), 7 deletions(-)
- create mode 100644 gcc/testsuite/gcc.c-torture/execute/pr119291.c
-
-diff --git a/gcc/combine.cc b/gcc/combine.cc
-index ef13f5d5e900..e87a9f272f1a 100644
---- a/gcc/combine.cc
-+++ b/gcc/combine.cc
-@@ -4012,18 +4012,18 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
-       rtx set1 = XVECEXP (newpat, 0, 1);
- 
-       /* Normally, it doesn't matter which of the two is done first, but
--	 one which uses any regs/memory set in between i2 and i3 can't
--	 be first.  The PARALLEL might also have been pre-existing in i3,
--	 so we need to make sure that we won't wrongly hoist a SET to i2
--	 that would conflict with a death note present in there, or would
--	 have its dest modified between i2 and i3.  */
-+	 one which uses any regs/memory set or used in between i2 and i3
-+	 can't be first.  The PARALLEL might also have been pre-existing
-+	 in i3, so we need to make sure that we won't wrongly hoist a SET
-+	 to i2 that would conflict with a death note present in there, or
-+	 would have its dest modified or used between i2 and i3.  */
-       if (!modified_between_p (SET_SRC (set1), i2, i3)
- 	  && !(REG_P (SET_DEST (set1))
- 	       && find_reg_note (i2, REG_DEAD, SET_DEST (set1)))
- 	  && !(GET_CODE (SET_DEST (set1)) == SUBREG
- 	       && find_reg_note (i2, REG_DEAD,
- 				 SUBREG_REG (SET_DEST (set1))))
--	  && !modified_between_p (SET_DEST (set1), i2, i3)
-+	  && !reg_used_between_p (SET_DEST (set1), i2, i3)
- 	  /* If I3 is a jump, ensure that set0 is a jump so that
- 	     we do not create invalid RTL.  */
- 	  && (!JUMP_P (i3) || SET_DEST (set0) == pc_rtx)
-@@ -4038,7 +4038,7 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
- 	       && !(GET_CODE (SET_DEST (set0)) == SUBREG
- 		    && find_reg_note (i2, REG_DEAD,
- 				      SUBREG_REG (SET_DEST (set0))))
--	       && !modified_between_p (SET_DEST (set0), i2, i3)
-+	       && !reg_used_between_p (SET_DEST (set0), i2, i3)
- 	       /* If I3 is a jump, ensure that set1 is a jump so that
- 		  we do not create invalid RTL.  */
- 	       && (!JUMP_P (i3) || SET_DEST (set1) == pc_rtx)
-diff --git a/gcc/testsuite/gcc.c-torture/execute/pr119291.c b/gcc/testsuite/gcc.c-torture/execute/pr119291.c
-new file mode 100644
-index 000000000000..41eadf013d7d
---- /dev/null
-+++ b/gcc/testsuite/gcc.c-torture/execute/pr119291.c
-@@ -0,0 +1,33 @@
-+/* PR rtl-optimization/119291 */
-+
-+int a;
-+long c;
-+
-+__attribute__((noipa)) void
-+foo (int x)
-+{
-+  if (x != 0)
-+    __builtin_abort ();
-+  a = 42;
-+}
-+
-+int
-+main ()
-+{
-+  int e = 1;
-+lab:
-+  if (a < 2)
-+    {
-+      int b = e;
-+      _Bool d = a != 0;
-+      _Bool f = b != 0;
-+      unsigned long g = -(d & f);
-+      unsigned long h = c & g;
-+      unsigned long i = ~c;
-+      e = -(i & h);
-+      c = e != 0;
-+      a = ~e + b;
-+      foo (e);
-+      goto lab;
-+    }
-+}
-
-base-commit: 9018336252463ffed28f01badfdea2a3ca3ba5c8
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/79_all_PR119291-combine-Special-case-set_noop_p-in-two-spots.patch b/15.0.0/gentoo/79_all_PR119291-combine-Special-case-set_noop_p-in-two-spots.patch
deleted file mode 100644
index 1cf964d..0000000
--- a/15.0.0/gentoo/79_all_PR119291-combine-Special-case-set_noop_p-in-two-spots.patch
+++ /dev/null
@@ -1,96 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/Z+aF8pEePd6K5xKf@tucnak/
-
-From fd39f47728c4e81e75c7150199fa368646cde9c3 Mon Sep 17 00:00:00 2001
-Message-ID: <fd39f47728c4e81e75c7150199fa368646cde9c3.1743258660.git.sam@gentoo.org>
-In-Reply-To: <8db4ff073981a554ab5b77f958fa4a333b981b30.1743258660.git.sam@gentoo.org>
-References: <8db4ff073981a554ab5b77f958fa4a333b981b30.1743258660.git.sam@gentoo.org>
-From: Jakub Jelinek <jakub@redhat.com>
-Date: Fri, 28 Mar 2025 12:20:18 +0100
-Subject: [PATCH 2/2] combine: Special case set_noop_p in two spots
-
-Hi!
-
-Here is the incremental patch I was talking about.
-For noop sets, we don't need to test much, they can go to i2
-unless that would violate i3 JUMP condition.
-
-With this the try_combine on the pr119291.c testcase doesn't fail,
-but succeeds and we get
-(insn 22 21 23 4 (set (pc)
-        (pc)) "pr119291.c":27:15 2147483647 {NOOP_MOVE}
-     (nil))
-(insn 23 22 24 4 (set (reg/v:SI 117 [ e ])
-        (reg/v:SI 116 [ e ])) 96 {*movsi_internal}
-     (expr_list:REG_DEAD (reg/v:SI 116 [ e ])
-        (nil)))
-(note 24 23 25 4 NOTE_INSN_DELETED)
-(insn 25 24 26 4 (set (reg/v:SI 116 [ e ])
-        (const_int 0 [0])) "pr119291.c":28:13 96 {*movsi_internal}
-     (nil))
-(note 26 25 27 4 NOTE_INSN_DELETED)
-(insn 27 26 28 4 (set (reg:DI 128 [ _9 ])
-        (const_int 0 [0])) "pr119291.c":28:13 95 {*movdi_internal}
-     (nil))
-after it.
-
-Ok for trunk if this passes bootstrap/regtest?
-
-2025-03-28  Jakub Jelinek  <jakub@redhat.com>
-
-	* combine.cc (try_combine): Sets which satisfy set_noop_p can go
-	to i2 unless i3 is a jump and the other set is not.
----
- gcc/combine.cc | 30 ++++++++++++++++--------------
- 1 file changed, 16 insertions(+), 14 deletions(-)
-
-diff --git a/gcc/combine.cc b/gcc/combine.cc
-index e87a9f272f1a..2be563bb018c 100644
---- a/gcc/combine.cc
-+++ b/gcc/combine.cc
-@@ -4017,13 +4017,14 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
- 	 in i3, so we need to make sure that we won't wrongly hoist a SET
- 	 to i2 that would conflict with a death note present in there, or
- 	 would have its dest modified or used between i2 and i3.  */
--      if (!modified_between_p (SET_SRC (set1), i2, i3)
--	  && !(REG_P (SET_DEST (set1))
--	       && find_reg_note (i2, REG_DEAD, SET_DEST (set1)))
--	  && !(GET_CODE (SET_DEST (set1)) == SUBREG
--	       && find_reg_note (i2, REG_DEAD,
--				 SUBREG_REG (SET_DEST (set1))))
--	  && !reg_used_between_p (SET_DEST (set1), i2, i3)
-+      if ((set_noop_p (set1)
-+	   || (!modified_between_p (SET_SRC (set1), i2, i3)
-+	       && !(REG_P (SET_DEST (set1))
-+		    && find_reg_note (i2, REG_DEAD, SET_DEST (set1)))
-+	       && !(GET_CODE (SET_DEST (set1)) == SUBREG
-+		    && find_reg_note (i2, REG_DEAD,
-+				      SUBREG_REG (SET_DEST (set1))))
-+	       && !reg_used_between_p (SET_DEST (set1), i2, i3)))
- 	  /* If I3 is a jump, ensure that set0 is a jump so that
- 	     we do not create invalid RTL.  */
- 	  && (!JUMP_P (i3) || SET_DEST (set0) == pc_rtx)
-@@ -4032,13 +4033,14 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
- 	  newi2pat = set1;
- 	  newpat = set0;
- 	}
--      else if (!modified_between_p (SET_SRC (set0), i2, i3)
--	       && !(REG_P (SET_DEST (set0))
--		    && find_reg_note (i2, REG_DEAD, SET_DEST (set0)))
--	       && !(GET_CODE (SET_DEST (set0)) == SUBREG
--		    && find_reg_note (i2, REG_DEAD,
--				      SUBREG_REG (SET_DEST (set0))))
--	       && !reg_used_between_p (SET_DEST (set0), i2, i3)
-+      else if ((set_noop_p (set0)
-+		|| (!modified_between_p (SET_SRC (set0), i2, i3)
-+		    && !(REG_P (SET_DEST (set0))
-+			 && find_reg_note (i2, REG_DEAD, SET_DEST (set0)))
-+		    && !(GET_CODE (SET_DEST (set0)) == SUBREG
-+			 && find_reg_note (i2, REG_DEAD,
-+					   SUBREG_REG (SET_DEST (set0))))
-+		    && !reg_used_between_p (SET_DEST (set0), i2, i3)))
- 	       /* If I3 is a jump, ensure that set1 is a jump so that
- 		  we do not create invalid RTL.  */
- 	       && (!JUMP_P (i3) || SET_DEST (set1) == pc_rtx)
--- 
-2.49.0
-
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-02  4:59 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-02  4:59 UTC (permalink / raw
  To: gentoo-commits
commit:     6f8b1c816299484f66a6184635b6202eb5ec72b0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  2 04:59:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr  2 04:59:45 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=6f8b1c81
15.0.0: add another tailcall patch (for eh this time)
This should fix protobuf.
Bug: https://gcc.gnu.org/PR119491
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch | 323 ++++++++++++++++++++++++
 15.0.0/gentoo/README.history                    |   1 +
 2 files changed, 324 insertions(+)
diff --git a/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch b/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch
new file mode 100644
index 0000000..339ba64
--- /dev/null
+++ b/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch
@@ -0,0 +1,323 @@
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c4
+
+2025-04-01  Jakub Jelinek  <jakub@redhat.com>
+
+	PR tree-optimization/119491
+	* tree-tailcall.cc (independent_of_stmt_p): Use
+	find_fallthru_edge (bb->succs)->dest instead of single_succ (bb).
+	(empty_eh_cleanup): New function.
+	(find_tail_calls): Diagnose throwing of exceptions which do not
+	propagate only if there are no EDGE_EH successor edges.  If there are
+	and the call is musttail, use empty_eh_cleanup to find if the cleanup
+	is not empty.  If not or the call is not musttail, use different
+	diagnostics.  Set is_noreturn even if there are successor edges.  Use
+	find_fallthru_edge (abb->succs) instead of single_succ_edge (abb).
+	(decrease_profile): Don't assert 0 or 1 successor edges.
+	(eliminate_tail_call): Use
+	find_fallthru_edge (gsi_bb (t->call_gsi)->succs) instead of
+	single_succ_edge (gsi_bb (t->call_gsi)).
+	(tree_optimize_tail_calls_1): Also look into basic blocks with
+	single succ edge which is EDGE_EH for noreturn musttail calls.
+
+	* g++.dg/opt/musttail3.C: New test.
+	* g++.dg/opt/musttail4.C: New test.
+	* g++.dg/opt/musttail5.C: New test.
+diff --git a/gcc/testsuite/g++.dg/opt/musttail3.C b/gcc/testsuite/g++.dg/opt/musttail3.C
+new file mode 100644
+index 000000000000..1c4e54952b1e
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/opt/musttail3.C
+@@ -0,0 +1,41 @@
++// PR tree-optimization/119491
++// { dg-do compile { target { external_musttail && c++11 } } }
++// { dg-options "-O2" }
++
++struct A {
++  struct B {};
++  A () {}
++};
++void qux ();
++unsigned char v;
++A w;
++void foo (A);
++
++template <typename T>
++[[gnu::always_inline]] static inline void
++bar (int &)
++{
++}
++
++[[gnu::always_inline]] static inline void
++baz (int *)
++{
++  int r = 0;
++  bar<int> (r);
++}
++
++[[gnu::always_inline]] inline void
++corge (A)
++{
++  if (v)
++    qux ();
++  [[gnu::musttail]] return foo (w);
++}
++
++void
++freddy (A)
++{
++  int t;
++  baz (&t);
++  [[gnu::musttail]] return corge (A{});
++}
+diff --git a/gcc/testsuite/g++.dg/opt/musttail4.C b/gcc/testsuite/g++.dg/opt/musttail4.C
+new file mode 100644
+index 000000000000..ede2959f7d74
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/opt/musttail4.C
+@@ -0,0 +1,35 @@
++// { dg-do compile { target { external_musttail && c++11 } } }
++// { dg-options "-O2 -fexceptions" }
++
++struct S { ~S (); };
++volatile int v;
++struct T { ~T () { v = v + 1; } };
++struct U { ~U () {} };
++int foo ();
++
++int
++bar () noexcept
++{
++  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: call may throw exception that does not propagate" }
++}
++
++int
++baz ()
++{
++  S s;
++  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: other reasons" }
++}
++
++int
++qux ()
++{
++  T t;
++  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: other reasons" }
++}
++
++int
++corge ()
++{
++  U u;
++  [[gnu::musttail]] return foo ();
++}
+diff --git a/gcc/testsuite/g++.dg/opt/musttail5.C b/gcc/testsuite/g++.dg/opt/musttail5.C
+new file mode 100644
+index 000000000000..604dd6907aa9
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/opt/musttail5.C
+@@ -0,0 +1,41 @@
++// PR tree-optimization/119491
++// { dg-do compile { target { external_musttail && c++11 } } }
++// { dg-options "-O2" }
++
++struct A {
++  struct B {};
++  A () {}
++};
++void qux ();
++unsigned char v;
++A w;
++[[noreturn]] void foo (A);
++
++template <typename T>
++[[gnu::always_inline]] static inline void
++bar (int &)
++{
++}
++
++[[gnu::always_inline]] static inline void
++baz (int *)
++{
++  int r = 0;
++  bar<int> (r);
++}
++
++[[gnu::always_inline]] inline void
++corge (A)
++{
++  if (v)
++    qux ();
++  [[gnu::musttail]] return foo (w);
++}
++
++void
++freddy (A)
++{
++  int t;
++  baz (&t);
++  [[gnu::musttail]] return corge (A{});
++}
+diff --git a/gcc/tree-tailcall.cc b/gcc/tree-tailcall.cc
+index e71341bfb2bc..b910dce7acbd 100644
+--- a/gcc/tree-tailcall.cc
++++ b/gcc/tree-tailcall.cc
+@@ -245,7 +245,7 @@ independent_of_stmt_p (tree expr, gimple *at, gimple_stmt_iterator gsi,
+   /* Mark the blocks in the chain leading to the end.  */
+   at_bb = gimple_bb (at);
+   call_bb = gimple_bb (gsi_stmt (gsi));
+-  for (bb = call_bb; bb != at_bb; bb = single_succ (bb))
++  for (bb = call_bb; bb != at_bb; bb = find_fallthru_edge (bb->succs)->dest)
+     bb->aux = &bb->aux;
+   bb->aux = &bb->aux;
+ 
+@@ -289,7 +289,7 @@ independent_of_stmt_p (tree expr, gimple *at, gimple_stmt_iterator gsi,
+     }
+ 
+   /* Unmark the blocks.  */
+-  for (bb = call_bb; bb != at_bb; bb = single_succ (bb))
++  for (bb = call_bb; bb != at_bb; bb = find_fallthru_edge (bb->succs)->dest)
+     bb->aux = NULL;
+   bb->aux = NULL;
+ 
+@@ -462,6 +462,33 @@ maybe_error_musttail (gcall *call, const char *err, bool diag_musttail)
+     }
+ }
+ 
++/* Return true if there is no real work performed in the exception
++   path starting at BB and it will in the end result in external exception.
++   Search at most CNT basic blocks (so that we don't need to do trivial
++   loop discovery).  */
++static bool
++empty_eh_cleanup (basic_block bb, int cnt)
++{
++  if (EDGE_COUNT (bb->succs) > 1)
++    return false;
++
++  for (gimple_stmt_iterator gsi = gsi_after_labels (bb); !gsi_end_p (gsi);
++       gsi_next (&gsi))
++    {
++      gimple *g = gsi_stmt (gsi);
++      if (is_gimple_debug (g) || gimple_clobber_p (g))
++	continue;
++      if (is_gimple_resx (g) && stmt_can_throw_external (cfun, g))
++	return true;
++      return false;
++    }
++  if (!single_succ_p (bb))
++    return false;
++  if (cnt == 1)
++    return false;
++  return empty_eh_cleanup (single_succ (bb), cnt - 1);
++}
++
+ /* Argument for compute_live_vars/live_vars_at_stmt and what compute_live_vars
+    returns.  Computed lazily, but just once for the function.  */
+ static live_vars_map *live_vars;
+@@ -612,14 +639,35 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
+   if ((stmt_could_throw_p (cfun, stmt)
+        && !stmt_can_throw_external (cfun, stmt)) || EDGE_COUNT (bb->succs) > 1)
+   {
+-    if (stmt == last_stmt)
+-      maybe_error_musttail (call,
+-			    _("call may throw exception that does not "
+-			      "propagate"), diag_musttail);
+-    else
+-      maybe_error_musttail (call, _("code between call and return"),
+-			    diag_musttail);
+-    return;
++    if (stmt != last_stmt)
++      {
++	maybe_error_musttail (call, _("code between call and return"),
++			      diag_musttail);
++	return;
++      }
++
++    edge e;
++    edge_iterator ei;
++    FOR_EACH_EDGE (e, ei, bb->succs)
++      if (e->flags & EDGE_EH)
++	break;
++
++    if (!e)
++      {
++	maybe_error_musttail (call,
++			      _("call may throw exception that does not "
++				"propagate"), diag_musttail);
++	return;
++      }
++
++    if (!gimple_call_must_tail_p (call)
++	|| !empty_eh_cleanup (e->dest, 20))
++      {
++	maybe_error_musttail (call,
++			      _("call may throw exception caught locally "
++				"or perform cleanups"), diag_musttail);
++	return;
++      }
+   }
+ 
+   /* If the function returns a value, then at present, the tail call
+@@ -763,8 +811,7 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
+   a = NULL_TREE;
+   auto_bitmap to_move_defs;
+   auto_vec<gimple *> to_move_stmts;
+-  bool is_noreturn
+-    = EDGE_COUNT (bb->succs) == 0 && gimple_call_noreturn_p (call);
++  bool is_noreturn = gimple_call_noreturn_p (call);
+ 
+   abb = bb;
+   agsi = gsi;
+@@ -776,8 +823,9 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
+ 
+       while (gsi_end_p (agsi))
+ 	{
+-	  ass_var = propagate_through_phis (ass_var, single_succ_edge (abb));
+-	  abb = single_succ (abb);
++	  edge e = find_fallthru_edge (abb->succs);
++	  ass_var = propagate_through_phis (ass_var, e);
++	  abb = e->dest;
+ 	  agsi = gsi_start_bb (abb);
+ 	}
+ 
+@@ -1112,11 +1160,6 @@ static void
+ decrease_profile (basic_block bb, profile_count count)
+ {
+   bb->count = bb->count - count;
+-  if (!single_succ_p (bb))
+-    {
+-      gcc_assert (!EDGE_COUNT (bb->succs));
+-      return;
+-    }
+ }
+ 
+ /* Eliminates tail call described by T.  TMP_VARS is a list of
+@@ -1181,7 +1224,7 @@ eliminate_tail_call (struct tailcall *t, class loop *&new_loop)
+   else
+     {
+       /* Number of executions of function has reduced by the tailcall.  */
+-      e = single_succ_edge (gsi_bb (t->call_gsi));
++      e = find_fallthru_edge (gsi_bb (t->call_gsi)->succs);
+ 
+       profile_count count = e->count ();
+ 
+@@ -1196,8 +1239,7 @@ eliminate_tail_call (struct tailcall *t, class loop *&new_loop)
+ 	decrease_profile (e->dest, count);
+ 
+       /* Replace the call by a jump to the start of function.  */
+-      e = redirect_edge_and_branch (single_succ_edge (gsi_bb (t->call_gsi)),
+-				    first);
++      e = redirect_edge_and_branch (e, first);
+     }
+   gcc_assert (e);
+   PENDING_STMT (e) = NULL;
+@@ -1362,7 +1404,9 @@ tree_optimize_tail_calls_1 (bool opt_tailcalls, bool only_musttail,
+     {
+       basic_block bb;
+       FOR_EACH_BB_FN (bb, cfun)
+-	if (EDGE_COUNT (bb->succs) == 0)
++	if (EDGE_COUNT (bb->succs) == 0
++	    || (single_succ_p (bb)
++		&& (single_succ_edge (bb)->flags & EDGE_EH)))
+ 	  if (gimple *c = last_nondebug_stmt (bb))
+ 	    if (is_gimple_call (c)
+ 		&& gimple_call_must_tail_p (as_a <gcall *> (c))
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 7e0990c..b497164 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,6 +1,7 @@
 51	????
 
 	+ 82_all_PR119318-ipa-cp.patch
+	+ 83_all_PR119491-tailcall-eh.patch
 
 50	31 March 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-02 13:56 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-02 13:56 UTC (permalink / raw
  To: gentoo-commits
commit:     966453b927f5030c1b2e858345091d867f78b94c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  2 13:55:41 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr  2 13:56:06 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=966453b9
15.0.0: update musttail patches
* Drop the "Don't fail" patch (merged upstream) for clang vs gnu::musttail
* Update eh musttail patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...-fail-musttail-calls-if-they-use-or-could.patch | 1124 --------------------
 15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch    |  339 +++---
 15.0.0/gentoo/README.history                       |    1 +
 3 files changed, 185 insertions(+), 1279 deletions(-)
diff --git a/15.0.0/gentoo/80_all_PR119376-tailc-Don-t-fail-musttail-calls-if-they-use-or-could.patch b/15.0.0/gentoo/80_all_PR119376-tailc-Don-t-fail-musttail-calls-if-they-use-or-could.patch
deleted file mode 100644
index d906b0c..0000000
--- a/15.0.0/gentoo/80_all_PR119376-tailc-Don-t-fail-musttail-calls-if-they-use-or-could.patch
+++ /dev/null
@@ -1,1124 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/Z+JccoSNxYWZIPz5@tucnak/
-
-From 4c5f092df307ec34b842483b1702d2e173e592a5 Mon Sep 17 00:00:00 2001
-Message-ID: <4c5f092df307ec34b842483b1702d2e173e592a5.1743280205.git.sam@gentoo.org>
-From: Jakub Jelinek <jakub@redhat.com>
-Date: Tue, 25 Mar 2025 08:34:10 +0100
-Subject: [PATCH] tailc: Don't fail musttail calls if they use or could use
- local arguments, instead warn [PR119376]
-
-Hi!
-
-As discussed here and in bugzilla, [[clang::musttail]] attribute in clang
-not just strongly asks for tail call or error, but changes behavior.
-To quote:
-https://clang.llvm.org/docs/AttributeReference.html#musttail
-"The lifetimes of all local variables and function parameters end immediately
-before the call to the function.  This means that it is undefined behaviour
-to pass a pointer or reference to a local variable to the called function,
-which is not the case without the attribute.  Clang will emit a warning in
-common cases where this happens."
-
-The GCC behavior was just to error if we can't prove the musttail callee
-could not have dereferenced escaped pointers to local vars or parameters
-of the caller.  That is still the case for variables with non-trivial
-destruction (even in clang), like vars with C++ non-trivial destructors or
-variables with cleanup attribute.
-
-The following patch changes the behavior to match that of clang, for all of
-[[clang::musttail]], [[gnu::musttail]] and __attribute__((musttail)).
-
-clang 20 actually added warning for some cases of it in
-https://github.com/llvm/llvm-project/pull/109255
-but it is under -Wreturn-stack-address warning.
-
-Now, gcc doesn't have that warning, but -Wreturn-local-addr instead, and
-IMHO it is better to have this under new warnings, because this isn't about
-returning local address, but about passing it to a musttail call, or maybe
-escaping to a musttail call.  And perhaps users will appreciate they can
-control it separately as well.
-
-The patch introduces 2 new warnings.
--Wmusttail-local-addr
-which is turn on by default and warns for the always dumb cases of passing
-an address of a local variable or parameter to musttail call's argument.
-And then
--Wmaybe-musttail-local-addr
-which is only diagnosed if -Wmusttail-local-addr was not diagnosed and
-diagnoses at most one (so that we don't emit 100s of warnings for one call
-if 100s of vars can escape) case where an address of a local var could have
-escaped to the musttail call.  This is less severe, the code doesn't have
-to be obviously wrong, so the warning is only enabled in -Wextra.
-
-And I've adjusted also the documentation for this change and addition of
-new warnings.
-
-Bootstrapped/regtested on x86_64-linux and i686-linux (on top of the
-just posted patch), ok for trunk?
-
-2025-03-25  Jakub Jelinek  <jakub@redhat.com>
-
-	PR ipa/119376
-	* common.opt (Wmusttail-local-addr, Wmaybe-musttail-local-addr): New.
-	* tree-tailcall.cc (suitable_for_tail_call_opt_p): Don't fail for
-	TREE_ADDRESSABLE PARM_DECLs for musttail calls if diag_musttail.
-	Emit -Wmusttail-local-addr warnings.
-	(maybe_error_musttail): Use gimple_location instead of directly
-	accessing location member.
-	(find_tail_calls): For musttail calls if diag_musttail, don't fail
-	if address of local could escape to the call, instead emit
-	-Wmaybe-musttail-local-addr warnings.  Emit
-	-Wmaybe-musttail-local-addr warnings also for address taken
-	parameters.
-	* common.opt.urls: Regenerate.
-	* doc/extend.texi (musttail statement attribute): Clarify local
-	variables without non-trivial destruction are considered out of scope
-	before the tail call instruction.
-	* doc/invoke.texi (-Wno-musttail-local-addr,
-	-Wmaybe-musttail-local-addr): Document.
-
-	* c-c++-common/musttail8.c: Expect a warning rather than error in one
-	case.
-	(f4): Add int * argument.
-	* c-c++-common/musttail15.c: Don't disallow for C++98.
-	* c-c++-common/musttail16.c: Likewise.
-	* c-c++-common/musttail17.c: Likewise.
-	* c-c++-common/musttail18.c: Likewise.
-	* c-c++-common/musttail19.c: Likewise.  Expect a warning rather than
-	error in one case.
-	(f4): Add int * argument.
-	* c-c++-common/musttail20.c: Don't disallow for C++98.
-	* c-c++-common/musttail21.c: Likewise.
-	* c-c++-common/musttail28.c: New test.
-	* c-c++-common/musttail29.c: New test.
-	* c-c++-common/musttail30.c: New test.
-	* c-c++-common/musttail31.c: New test.
-	* g++.dg/ext/musttail1.C: New test.
-	* g++.dg/ext/musttail2.C: New test.
-	* g++.dg/ext/musttail3.C: New test.
----
- gcc/common.opt                          |   8 ++
- gcc/common.opt.urls                     |   6 ++
- gcc/doc/extend.texi                     |  49 ++++++++++-
- gcc/doc/invoke.texi                     |  52 ++++++++++-
- gcc/testsuite/c-c++-common/musttail15.c |   2 +-
- gcc/testsuite/c-c++-common/musttail16.c |   2 +-
- gcc/testsuite/c-c++-common/musttail17.c |   2 +-
- gcc/testsuite/c-c++-common/musttail18.c |   2 +-
- gcc/testsuite/c-c++-common/musttail19.c |   7 +-
- gcc/testsuite/c-c++-common/musttail20.c |   2 +-
- gcc/testsuite/c-c++-common/musttail21.c |   2 +-
- gcc/testsuite/c-c++-common/musttail28.c | 108 +++++++++++++++++++++++
- gcc/testsuite/c-c++-common/musttail29.c | 109 ++++++++++++++++++++++++
- gcc/testsuite/c-c++-common/musttail30.c | 109 ++++++++++++++++++++++++
- gcc/testsuite/c-c++-common/musttail31.c | 109 ++++++++++++++++++++++++
- gcc/testsuite/c-c++-common/musttail8.c  |   5 +-
- gcc/testsuite/g++.dg/ext/musttail1.C    |  38 +++++++++
- gcc/testsuite/g++.dg/ext/musttail2.C    |  38 +++++++++
- gcc/testsuite/g++.dg/ext/musttail3.C    |  37 ++++++++
- gcc/tree-tailcall.cc                    |  97 +++++++++++++++++++--
- 20 files changed, 760 insertions(+), 24 deletions(-)
- create mode 100644 gcc/testsuite/c-c++-common/musttail28.c
- create mode 100644 gcc/testsuite/c-c++-common/musttail29.c
- create mode 100644 gcc/testsuite/c-c++-common/musttail30.c
- create mode 100644 gcc/testsuite/c-c++-common/musttail31.c
- create mode 100644 gcc/testsuite/g++.dg/ext/musttail1.C
- create mode 100644 gcc/testsuite/g++.dg/ext/musttail2.C
- create mode 100644 gcc/testsuite/g++.dg/ext/musttail3.C
-
-diff --git a/gcc/common.opt b/gcc/common.opt
-index 2da02866ca08..9400c4b94e88 100644
---- a/gcc/common.opt
-+++ b/gcc/common.opt
-@@ -693,6 +693,14 @@ Does nothing. Preserved for backward compatibility.
- Wmissing-noreturn
- Common Warning Alias(Wsuggest-attribute=noreturn)
- 
-+Wmusttail-local-addr
-+Common Var(warn_musttail_local_addr) Init(1) Warning
-+Warn about passing a pointer/reference to a local or temporary variable to a musttail call argument.
-+
-+Wmaybe-musttail-local-addr
-+Common Var(warn_maybe_musttail_local_addr) Warning EnabledBy(Wextra)
-+Warn about pointer/reference to a local or temporary variable possibly escaping to a musttail call.
-+
- Wodr
- Common Var(warn_odr_violations) Init(1) Warning
- Warn about some C++ One Definition Rule violations during link time optimization.
-diff --git a/gcc/common.opt.urls b/gcc/common.opt.urls
-index e7900c825c17..860ebd01ace2 100644
---- a/gcc/common.opt.urls
-+++ b/gcc/common.opt.urls
-@@ -157,6 +157,12 @@ UrlSuffix(gcc/Warning-Options.html#index-Wno-unsafe-loop-optimizations)
- Wmissing-noreturn
- UrlSuffix(gcc/Warning-Options.html#index-Wmissing-noreturn)
- 
-+Wmusttail-local-addr
-+UrlSuffix(gcc/Warning-Options.html#index-Wno-musttail-local-addr)
-+
-+Wmaybe-musttail-local-addr
-+UrlSuffix(gcc/Warning-Options.html#index-Wmaybe-musttail-local-addr)
-+
- Wodr
- UrlSuffix(gcc/Warning-Options.html#index-Wno-odr)
- 
-diff --git a/gcc/doc/extend.texi b/gcc/doc/extend.texi
-index ed766e53dcc4..fcb6df95dcf5 100644
---- a/gcc/doc/extend.texi
-+++ b/gcc/doc/extend.texi
-@@ -9282,10 +9282,51 @@ __attribute__((musttail)) return bar();
- 
- If the compiler cannot generate a @code{musttail} tail call it will report
- an error.  On some targets tail calls may never be supported.
--Tail calls cannot reference locals in memory, which may affect
--builds without optimization when passing small structures, or passing
--or returning large structures.  Enabling @option{-O1} or @option{-O2} can
--improve the success of tail calls.
-+The user asserts for @code{musttail} tail calls that lifetime of automatic
-+variables, function parameters and temporaries (unless they have non-trivial
-+destruction) can end before the actual call instruction and that any access
-+to those from inside of the called function results is considered undefined
-+behavior.  Enabling @option{-O1} or @option{-O2} can improve the success of
-+tail calls.
-+
-+@smallexample
-+int foo (int *);
-+void bar (int *);
-+struct S @{ S (); ~S (); int s; @};
-+
-+int
-+baz (int *x)
-+@{
-+  if (*x == 1)
-+    @{
-+      int a = 42;
-+      /* The call will be tail called (would not be without the
-+         attribute), dereferencing the pointer in the callee is
-+         undefined behavior and there will be a warning emitted
-+         for this by default (@option{-Wmusttail-local-addr}).  */
-+      [[gnu::musttail]] return foo (&a);
-+    @}
-+  else if (*x == 2)
-+    @{
-+      int a = 42;
-+      bar (&a);
-+      /* The call will be tail called (would not be without the
-+         attribute), if bar stores the pointer anywhere, dereferencing
-+         it in foo will be undefined behavior and there will be a warning
-+         emitted for this with @option{-Wextra}, which implies
-+         @option{-Wmaybe-musttail-local-addr}.  */
-+      [[gnu::musttail]] return foo (nullptr);
-+    @}
-+  else
-+    @{
-+      S s;
-+      /* The s variable requires non-trivial destruction which ought
-+         to be performed after the foo call returns, so this will
-+         be rejected.  */
-+      [[gnu::musttail]] return foo (&s.s);
-+    @}
-+@}
-+@end smallexample
- @end table
- 
- @node Attribute Syntax
-diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
-index df4610908243..2617406b7691 100644
---- a/gcc/doc/invoke.texi
-+++ b/gcc/doc/invoke.texi
-@@ -394,7 +394,8 @@ Objective-C and Objective-C++ Dialects}.
- -Wmemset-elt-size  -Wmemset-transposed-args
- -Wmisleading-indentation  -Wmissing-attributes  -Wmissing-braces
- -Wmissing-field-initializers  -Wmissing-format-attribute
---Wmissing-include-dirs  -Wmissing-noreturn  -Wno-missing-profile
-+-Wmissing-include-dirs  -Wmissing-noreturn  -Wmusttail-local-addr
-+-Wmaybe-musttail-local-addr  -Wno-missing-profile
- -Wno-multichar  -Wmultistatement-macros  -Wnonnull  -Wnonnull-compare
- -Wnormalized=@r{[}none@r{|}id@r{|}nfc@r{|}nfkc@r{]}
- -Wnull-dereference  -Wno-odr
-@@ -6975,6 +6976,55 @@ is only active when @option{-fdelete-null-pointer-checks} is active,
- which is enabled by optimizations in most targets.  The precision of
- the warnings depends on the optimization options used.
- 
-+@opindex Wno-musttail-local-addr
-+@opindex -Wmusttail-local-addr
-+@item -Wno-musttail-local-addr
-+Do not warn about passing a pointer (or in C++, a reference) to a
-+local variable or label to argument of a @code{musttail} call.  Those
-+variables go out of scope before the tail call instruction.
-+
-+@opindex Wmaybe-musttail-local-addr
-+@opindex -Wno-maybe-musttail-local-addr
-+@item -Wmaybe-musttail-local-addr
-+Warn when address of a local variable can escape to a @code{musttail}
-+call, unless it goes out of scope already before the @code{musttail}
-+call.
-+
-+@smallexample
-+int foo (int *);
-+
-+int
-+bar (int *x)
-+@{
-+  if (x[0] == 1)
-+    @{
-+      int a = 42;
-+      foo (&a);
-+      /* Without the @code{musttail} attribute this call would not
-+         be tail called, because address of the @code{a} variable escapes
-+         and the second foo call could dereference it.  With the attribute
-+         the local variables are assumed to go out of scope immediately
-+         before the tail call instruction and the compiler warns about
-+         this.  */
-+      [[gnu::musttail]] return foo (nullptr);
-+    @}
-+  else
-+    @{
-+      @{
-+        int a = 42;
-+        foo (&a);
-+      @}
-+      /* The @code{a} variable isn't already in scope, so even when it
-+         escaped, even without @code{musttail} attribute it would be
-+         undefined behavior to dereference it and the compiler could
-+         turn this into a tail call.  No warning is diagnosed here.  */
-+      [[gnu::musttail]] return foo (nullptr);
-+    @}
-+@}
-+@end smallexample
-+
-+This warning is enabled by @option{-Wextra}.
-+
- @opindex Wnrvo
- @opindex Wno-nrvo
- @item -Wnrvo @r{(C++ and Objective-C++ only)}
-diff --git a/gcc/testsuite/c-c++-common/musttail15.c b/gcc/testsuite/c-c++-common/musttail15.c
-index 2addc971922c..b8223d77fd56 100644
---- a/gcc/testsuite/c-c++-common/musttail15.c
-+++ b/gcc/testsuite/c-c++-common/musttail15.c
-@@ -1,4 +1,4 @@
--/* { dg-do compile { target { musttail && { c || c++11 } } } } */
-+/* { dg-do compile { target musttail } } */
- /* { dg-additional-options "-fdelayed-branch" { target sparc*-*-* } } */
- 
- int __attribute__((noinline,noclone,noipa))
-diff --git a/gcc/testsuite/c-c++-common/musttail16.c b/gcc/testsuite/c-c++-common/musttail16.c
-index b1e2ff3e6dc8..f27a27923314 100644
---- a/gcc/testsuite/c-c++-common/musttail16.c
-+++ b/gcc/testsuite/c-c++-common/musttail16.c
-@@ -1,4 +1,4 @@
--/* { dg-do compile { target { musttail && { c || c++11 } } } } */
-+/* { dg-do compile { target musttail } } */
- 
- struct box { char field[256]; int i; };
- 
-diff --git a/gcc/testsuite/c-c++-common/musttail17.c b/gcc/testsuite/c-c++-common/musttail17.c
-index 490f3c35ca23..58fab84993bf 100644
---- a/gcc/testsuite/c-c++-common/musttail17.c
-+++ b/gcc/testsuite/c-c++-common/musttail17.c
-@@ -1,4 +1,4 @@
--/* { dg-do compile { target { musttail && { c || c++11 } } } } */
-+/* { dg-do compile { target musttail } } */
- 
- struct box { char field[64]; int i; };
- 
-diff --git a/gcc/testsuite/c-c++-common/musttail18.c b/gcc/testsuite/c-c++-common/musttail18.c
-index 4f34a8d27f36..ab608871fd08 100644
---- a/gcc/testsuite/c-c++-common/musttail18.c
-+++ b/gcc/testsuite/c-c++-common/musttail18.c
-@@ -1,4 +1,4 @@
--/* { dg-do compile { target { musttail && { c || c++11 } } } } */
-+/* { dg-do compile { target musttail } } */
- /* { dg-additional-options "-fdelayed-branch" { target sparc*-*-* } } */
- 
- void __attribute__((noipa)) f() {}
-diff --git a/gcc/testsuite/c-c++-common/musttail19.c b/gcc/testsuite/c-c++-common/musttail19.c
-index 70f9eaff139c..a592b69c1b7c 100644
---- a/gcc/testsuite/c-c++-common/musttail19.c
-+++ b/gcc/testsuite/c-c++-common/musttail19.c
-@@ -1,4 +1,4 @@
--/* { dg-do compile { target { musttail && { c || c++11 } } } } */
-+/* { dg-do compile { target musttail } } */
- 
- float f1(void);
- 
-@@ -10,8 +10,9 @@ int f2(void)
- 
- int f3(int *);
- 
--int f4(void)
-+int f4(int *p)
- {
-   int x;
--  __attribute__((musttail)) return f3(&x); /* { dg-error "\(refers to locals|other reasons\)" } */
-+  (void) p;
-+  __attribute__((musttail)) return f3(&x); /* { dg-warning "address of automatic variable 'x' passed to 'musttail' call argument" } */
- }
-diff --git a/gcc/testsuite/c-c++-common/musttail20.c b/gcc/testsuite/c-c++-common/musttail20.c
-index 70f14ff2f217..1931f2cc8e4a 100644
---- a/gcc/testsuite/c-c++-common/musttail20.c
-+++ b/gcc/testsuite/c-c++-common/musttail20.c
-@@ -1,4 +1,4 @@
--/* { dg-do compile { target { struct_musttail && { c || c++11 } } } } */
-+/* { dg-do compile { target struct_musttail } } */
- /* { dg-additional-options "-fdelayed-branch" { target sparc*-*-* } } */
- 
- struct str
-diff --git a/gcc/testsuite/c-c++-common/musttail21.c b/gcc/testsuite/c-c++-common/musttail21.c
-index 954209ddcd51..1a109e1955dc 100644
---- a/gcc/testsuite/c-c++-common/musttail21.c
-+++ b/gcc/testsuite/c-c++-common/musttail21.c
-@@ -1,4 +1,4 @@
--/* { dg-do compile { target { c || c++11 } } } */
-+/* { dg-do compile { target musttail } } */
- void f(void)
- {
-   __attribute__((musttail)) return; /* { dg-error "cannot tail-call.*return value must be a call" } */
-diff --git a/gcc/testsuite/c-c++-common/musttail28.c b/gcc/testsuite/c-c++-common/musttail28.c
-new file mode 100644
-index 000000000000..d84658aa8a05
---- /dev/null
-+++ b/gcc/testsuite/c-c++-common/musttail28.c
-@@ -0,0 +1,108 @@
-+/* { dg-do compile { target { musttail && { c || c++11 } } } } */
-+
-+int foo (int, void *);
-+int bar (int, int *);
-+struct S { int a, b, c; };
-+struct T { int d; struct S e; };
-+
-+int
-+baz (int x, void *y)
-+{
-+  [[gnu::musttail]] return bar (2, &x);		/* { dg-warning "address of parameter 'x' passed to 'musttail' call argument" } */
-+}
-+
-+int
-+qux (int x, void *y)
-+{
-+  __label__ lab;
-+  lab:;
-+  if (*(int *) y == 1)
-+    [[gnu::musttail]] return foo (1, &&lab);	/* { dg-warning "address of label passed to 'musttail' call argument" } */
-+  if (x == 1)
-+    [[gnu::musttail]] return foo (3, 0);
-+  else if (x == 2)
-+    {
-+      {
-+        int a = 42;
-+        bar (4, &a);
-+      }
-+      [[gnu::musttail]] return bar (5, 0);
-+    }
-+  else if (x == 3)
-+    {
-+      int a = 42;
-+      bar (4, &a);
-+      [[gnu::musttail]] return bar (6, 0);
-+    }
-+  else if (x == 4)
-+    {
-+      int a = 42;
-+      [[gnu::musttail]] return bar (7, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 5)
-+    {
-+      struct T b;
-+      [[gnu::musttail]] return bar (8, &b.e.b);	/* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 6)
-+    {
-+      struct T b;
-+      bar (9, &b.e.a);
-+      [[gnu::musttail]] return bar (10, 0);
-+    }
-+  else if (x == 7)
-+    {
-+      {
-+        struct T b;
-+        bar (9, &b.e.a);
-+      }
-+      [[gnu::musttail]] return bar (11, 0);
-+    }
-+  else if (x == 8)
-+    {
-+      {
-+        int a = 42;
-+        bar (4, &a);
-+      }
-+      [[gnu::musttail]] return foo (12, 0);
-+    }
-+  else if (x == 9)
-+    {
-+      int a = 42;
-+      bar (4, &a);
-+      [[gnu::musttail]] return foo (13, 0);
-+    }
-+  else if (x == 10)
-+    {
-+      int a = 42;
-+      [[gnu::musttail]] return foo (14, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 11)
-+    {
-+      struct T b;
-+      [[gnu::musttail]] return foo (15, &b.e.b); /* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 12)
-+    {
-+      struct T b;
-+      bar (9, &b.e.a);
-+      [[gnu::musttail]] return foo (16, 0);
-+    }
-+  else if (x == 13)
-+    {
-+      {
-+        struct T b;
-+        bar (9, &b.e.a);
-+      }
-+      [[gnu::musttail]] return foo (17, 0);
-+    }
-+  return 0;
-+}
-+
-+int
-+corge (int x, void *y)
-+{
-+  if (*(int *) y == 1)
-+    bar (18, &x);
-+  [[gnu::musttail]] return bar (2, 0);
-+}
-diff --git a/gcc/testsuite/c-c++-common/musttail29.c b/gcc/testsuite/c-c++-common/musttail29.c
-new file mode 100644
-index 000000000000..f6b3d76abe11
---- /dev/null
-+++ b/gcc/testsuite/c-c++-common/musttail29.c
-@@ -0,0 +1,109 @@
-+/* { dg-do compile { target { musttail && { c || c++11 } } } } */
-+/* { dg-options "-O2 -Wmusttail-local-addr" } */
-+
-+int foo (int, void *);
-+int bar (int, int *);
-+struct S { int a, b, c; };
-+struct T { int d; struct S e; };
-+
-+int
-+baz (int x, void *y)
-+{
-+  [[gnu::musttail]] return bar (2, &x);		/* { dg-warning "address of parameter 'x' passed to 'musttail' call argument" } */
-+}
-+
-+int
-+qux (int x, void *y)
-+{
-+  __label__ lab;
-+  lab:;
-+  if (*(int *) y == 1)
-+    [[gnu::musttail]] return foo (1, &&lab);	/* { dg-warning "address of label passed to 'musttail' call argument" } */
-+  if (x == 1)
-+    [[gnu::musttail]] return foo (3, 0);
-+  else if (x == 2)
-+    {
-+      {
-+        int a = 42;
-+        bar (4, &a);
-+      }
-+      [[gnu::musttail]] return bar (5, 0);
-+    }
-+  else if (x == 3)
-+    {
-+      int a = 42;
-+      bar (4, &a);
-+      [[gnu::musttail]] return bar (6, 0);
-+    }
-+  else if (x == 4)
-+    {
-+      int a = 42;
-+      [[gnu::musttail]] return bar (7, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 5)
-+    {
-+      struct T b;
-+      [[gnu::musttail]] return bar (8, &b.e.b);	/* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 6)
-+    {
-+      struct T b;
-+      bar (9, &b.e.a);
-+      [[gnu::musttail]] return bar (10, 0);
-+    }
-+  else if (x == 7)
-+    {
-+      {
-+        struct T b;
-+        bar (9, &b.e.a);
-+      }
-+      [[gnu::musttail]] return bar (11, 0);
-+    }
-+  else if (x == 8)
-+    {
-+      {
-+        int a = 42;
-+        bar (4, &a);
-+      }
-+      [[gnu::musttail]] return foo (12, 0);
-+    }
-+  else if (x == 9)
-+    {
-+      int a = 42;
-+      bar (4, &a);
-+      [[gnu::musttail]] return foo (13, 0);
-+    }
-+  else if (x == 10)
-+    {
-+      int a = 42;
-+      [[gnu::musttail]] return foo (14, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 11)
-+    {
-+      struct T b;
-+      [[gnu::musttail]] return foo (15, &b.e.b); /* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 12)
-+    {
-+      struct T b;
-+      bar (9, &b.e.a);
-+      [[gnu::musttail]] return foo (16, 0);
-+    }
-+  else if (x == 13)
-+    {
-+      {
-+        struct T b;
-+        bar (9, &b.e.a);
-+      }
-+      [[gnu::musttail]] return foo (17, 0);
-+    }
-+  return 0;
-+}
-+
-+int
-+corge (int x, void *y)
-+{
-+  if (*(int *) y == 1)
-+    bar (18, &x);
-+  [[gnu::musttail]] return bar (2, 0);
-+}
-diff --git a/gcc/testsuite/c-c++-common/musttail30.c b/gcc/testsuite/c-c++-common/musttail30.c
-new file mode 100644
-index 000000000000..be1c3daf6af2
---- /dev/null
-+++ b/gcc/testsuite/c-c++-common/musttail30.c
-@@ -0,0 +1,109 @@
-+/* { dg-do compile { target { musttail && { c || c++11 } } } } */
-+/* { dg-options "-Wextra" } */
-+
-+int foo (int, void *);
-+int bar (int, int *);
-+struct S { int a, b, c; };
-+struct T { int d; struct S e; };
-+
-+int
-+baz (int x, void *y)
-+{
-+  [[gnu::musttail]] return bar (2, &x);		/* { dg-warning "address of parameter 'x' passed to 'musttail' call argument" } */
-+}
-+
-+int
-+qux (int x, void *y)
-+{
-+  __label__ lab;
-+  lab:;
-+  if (*(int *) y == 1)
-+    [[gnu::musttail]] return foo (1, &&lab);	/* { dg-warning "address of label passed to 'musttail' call argument" } */
-+  if (x == 1)
-+    [[gnu::musttail]] return foo (3, 0);
-+  else if (x == 2)
-+    {
-+      {
-+        int a = 42;
-+        bar (4, &a);
-+      }
-+      [[gnu::musttail]] return bar (5, 0);
-+    }
-+  else if (x == 3)
-+    {
-+      int a = 42;
-+      bar (4, &a);
-+      [[gnu::musttail]] return bar (6, 0);	/* { dg-warning "address of automatic variable 'a' can escape to 'musttail' call" } */
-+    }
-+  else if (x == 4)
-+    {
-+      int a = 42;
-+      [[gnu::musttail]] return bar (7, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 5)
-+    {
-+      struct T b;
-+      [[gnu::musttail]] return bar (8, &b.e.b);	/* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 6)
-+    {
-+      struct T b;
-+      bar (9, &b.e.a);
-+      [[gnu::musttail]] return bar (10, 0);	/* { dg-warning "address of automatic variable 'b' can escape to 'musttail' call" } */
-+    }
-+  else if (x == 7)
-+    {
-+      {
-+        struct T b;
-+        bar (9, &b.e.a);
-+      }
-+      [[gnu::musttail]] return bar (11, 0);
-+    }
-+  else if (x == 8)
-+    {
-+      {
-+        int a = 42;
-+        bar (4, &a);
-+      }
-+      [[gnu::musttail]] return foo (12, 0);
-+    }
-+  else if (x == 9)
-+    {
-+      int a = 42;
-+      bar (4, &a);
-+      [[gnu::musttail]] return foo (13, 0);	/* { dg-warning "address of automatic variable 'a' can escape to 'musttail' call" } */
-+    }
-+  else if (x == 10)
-+    {
-+      int a = 42;
-+      [[gnu::musttail]] return foo (14, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 11)
-+    {
-+      struct T b;
-+      [[gnu::musttail]] return foo (15, &b.e.b); /* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 12)
-+    {
-+      struct T b;
-+      bar (9, &b.e.a);
-+      [[gnu::musttail]] return foo (16, 0);	/* { dg-warning "address of automatic variable 'b' can escape to 'musttail' call" } */
-+    }
-+  else if (x == 13)
-+    {
-+      {
-+        struct T b;
-+        bar (9, &b.e.a);
-+      }
-+      [[gnu::musttail]] return foo (17, 0);
-+    }
-+  return 0;
-+}
-+
-+int
-+corge (int x, void *y)
-+{
-+  if (*(int *) y == 1)
-+    bar (18, &x);
-+  [[gnu::musttail]] return bar (2, 0);		/* { dg-warning "address of parameter 'x' can escape to 'musttail' call" } */
-+}
-diff --git a/gcc/testsuite/c-c++-common/musttail31.c b/gcc/testsuite/c-c++-common/musttail31.c
-new file mode 100644
-index 000000000000..f44ada4d4733
---- /dev/null
-+++ b/gcc/testsuite/c-c++-common/musttail31.c
-@@ -0,0 +1,109 @@
-+/* { dg-do compile { target { musttail && { c || c++11 } } } } */
-+/* { dg-options "-O2 -Wmaybe-musttail-local-addr" } */
-+
-+int foo (int, void *);
-+int bar (int, int *);
-+struct S { int a, b, c; };
-+struct T { int d; struct S e; };
-+
-+int
-+baz (int x, void *y)
-+{
-+  [[gnu::musttail]] return bar (2, &x);		/* { dg-warning "address of parameter 'x' passed to 'musttail' call argument" } */
-+}
-+
-+int
-+qux (int x, void *y)
-+{
-+  __label__ lab;
-+  lab:;
-+  if (*(int *) y == 1)
-+    [[gnu::musttail]] return foo (1, &&lab);	/* { dg-warning "address of label passed to 'musttail' call argument" } */
-+  if (x == 1)
-+    [[gnu::musttail]] return foo (3, 0);
-+  else if (x == 2)
-+    {
-+      {
-+        int a = 42;
-+        bar (4, &a);
-+      }
-+      [[gnu::musttail]] return bar (5, 0);
-+    }
-+  else if (x == 3)
-+    {
-+      int a = 42;
-+      bar (4, &a);
-+      [[gnu::musttail]] return bar (6, 0);	/* { dg-warning "address of automatic variable 'a' can escape to 'musttail' call" } */
-+    }
-+  else if (x == 4)
-+    {
-+      int a = 42;
-+      [[gnu::musttail]] return bar (7, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 5)
-+    {
-+      struct T b;
-+      [[gnu::musttail]] return bar (8, &b.e.b);	/* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 6)
-+    {
-+      struct T b;
-+      bar (9, &b.e.a);
-+      [[gnu::musttail]] return bar (10, 0);	/* { dg-warning "address of automatic variable 'b' can escape to 'musttail' call" } */
-+    }
-+  else if (x == 7)
-+    {
-+      {
-+        struct T b;
-+        bar (9, &b.e.a);
-+      }
-+      [[gnu::musttail]] return bar (11, 0);
-+    }
-+  else if (x == 8)
-+    {
-+      {
-+        int a = 42;
-+        bar (4, &a);
-+      }
-+      [[gnu::musttail]] return foo (12, 0);
-+    }
-+  else if (x == 9)
-+    {
-+      int a = 42;
-+      bar (4, &a);
-+      [[gnu::musttail]] return foo (13, 0);	/* { dg-warning "address of automatic variable 'a' can escape to 'musttail' call" } */
-+    }
-+  else if (x == 10)
-+    {
-+      int a = 42;
-+      [[gnu::musttail]] return foo (14, &a);	/* { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 11)
-+    {
-+      struct T b;
-+      [[gnu::musttail]] return foo (15, &b.e.b); /* { dg-warning "address of automatic variable 'b' passed to 'musttail' call argument" } */
-+    }
-+  else if (x == 12)
-+    {
-+      struct T b;
-+      bar (9, &b.e.a);
-+      [[gnu::musttail]] return foo (16, 0);	/* { dg-warning "address of automatic variable 'b' can escape to 'musttail' call" } */
-+    }
-+  else if (x == 13)
-+    {
-+      {
-+        struct T b;
-+        bar (9, &b.e.a);
-+      }
-+      [[gnu::musttail]] return foo (17, 0);
-+    }
-+  return 0;
-+}
-+
-+int
-+corge (int x, void *y)
-+{
-+  if (*(int *) y == 1)
-+    bar (18, &x);
-+  [[gnu::musttail]] return bar (2, 0);		/* { dg-warning "address of parameter 'x' can escape to 'musttail' call" } */
-+}
-diff --git a/gcc/testsuite/c-c++-common/musttail8.c b/gcc/testsuite/c-c++-common/musttail8.c
-index 50ca1ac0dd48..9a29030a3b06 100644
---- a/gcc/testsuite/c-c++-common/musttail8.c
-+++ b/gcc/testsuite/c-c++-common/musttail8.c
-@@ -10,8 +10,9 @@ int f2(void)
- 
- int f3(int *);
- 
--int f4(void)
-+int f4(int *p)
- {
-   int x;
--  [[gnu::musttail]] return f3(&x); /* { dg-error "\(refers to locals|other reasons\)" } */
-+  (void) p;
-+  [[gnu::musttail]] return f3(&x); /* { dg-warning "address of automatic variable 'x' passed to 'musttail' call argument" } */
- }
-diff --git a/gcc/testsuite/g++.dg/ext/musttail1.C b/gcc/testsuite/g++.dg/ext/musttail1.C
-new file mode 100644
-index 000000000000..fd9b386a5974
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/ext/musttail1.C
-@@ -0,0 +1,38 @@
-+// PR ipa/119376
-+// { dg-do compile { target { musttail && c++11 } } }
-+// { dg-options "-Wmaybe-musttail-local-addr" }
-+
-+int foo (int &);
-+int bar (int &&);
-+int corge (int *);
-+
-+int
-+baz (int &x)
-+{
-+  if (x == 1)
-+    [[gnu::musttail]] return foo (x);
-+  if (x == 2)
-+    {
-+      int a = 42;
-+      [[gnu::musttail]] return foo (a);		// { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" }
-+    }
-+  if (x == 3)
-+    {
-+      int a = 42;
-+      foo (a);
-+      [[gnu::musttail]] return foo (x);		// { dg-warning "address of automatic variable 'a' can escape to 'musttail' call" }
-+    }
-+  return 0;
-+}
-+
-+int
-+qux (int &&x)
-+{
-+  [[gnu::musttail]] return bar (x + 1);		// { dg-warning "address of local variable passed to 'musttail' call argument" }
-+}
-+
-+int
-+freddy (int x)
-+{
-+  [[gnu::musttail]] return foo (x);		// { dg-warning "address of parameter 'x' passed to 'musttail' call argument" }
-+}
-diff --git a/gcc/testsuite/g++.dg/ext/musttail2.C b/gcc/testsuite/g++.dg/ext/musttail2.C
-new file mode 100644
-index 000000000000..ac99aafb0f0c
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/ext/musttail2.C
-@@ -0,0 +1,38 @@
-+// PR ipa/119376
-+// { dg-do compile { target { musttail && c++11 } } }
-+// { dg-options "-Wextra" }
-+
-+int foo (int &);
-+int bar (int &&);
-+int corge (int *);
-+
-+int
-+baz (int &x)
-+{
-+  if (x == 1)
-+    [[clang::musttail]] return foo (x);
-+  if (x == 2)
-+    {
-+      int a = 42;
-+      [[clang::musttail]] return foo (a);		// { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" }
-+    }
-+  if (x == 3)
-+    {
-+      int a = 42;
-+      foo (a);
-+      [[clang::musttail]] return foo (x);		// { dg-warning "address of automatic variable 'a' can escape to 'musttail' call" }
-+    }
-+  return 0;
-+}
-+
-+int
-+qux (int &&x)
-+{
-+  [[clang::musttail]] return bar (x + 1);		// { dg-warning "address of local variable passed to 'musttail' call argument" }
-+}
-+
-+int
-+freddy (int x)
-+{
-+  [[clang::musttail]] return foo (x);			// { dg-warning "address of parameter 'x' passed to 'musttail' call argument" }
-+}
-diff --git a/gcc/testsuite/g++.dg/ext/musttail3.C b/gcc/testsuite/g++.dg/ext/musttail3.C
-new file mode 100644
-index 000000000000..1c4b939a2a43
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/ext/musttail3.C
-@@ -0,0 +1,37 @@
-+// PR ipa/119376
-+// { dg-do compile { target { musttail && c++11 } } }
-+
-+int foo (int &);
-+int bar (int &&);
-+int corge (int *);
-+
-+int
-+baz (int &x)
-+{
-+  if (x == 1)
-+    [[gnu::musttail]] return foo (x);
-+  if (x == 2)
-+    {
-+      int a = 42;
-+      [[gnu::musttail]] return foo (a);		// { dg-warning "address of automatic variable 'a' passed to 'musttail' call argument" }
-+    }
-+  if (x == 3)
-+    {
-+      int a = 42;
-+      foo (a);
-+      [[gnu::musttail]] return foo (x);
-+    }
-+  return 0;
-+}
-+
-+int
-+qux (int &&x)
-+{
-+  [[gnu::musttail]] return bar (x + 1);		// { dg-warning "address of local variable passed to 'musttail' call argument" }
-+}
-+
-+int
-+freddy (int x)
-+{
-+  [[gnu::musttail]] return foo (x);		// { dg-warning "address of parameter 'x' passed to 'musttail' call argument" }
-+}
-diff --git a/gcc/tree-tailcall.cc b/gcc/tree-tailcall.cc
-index 8ba675221915..e025a1cb78b2 100644
---- a/gcc/tree-tailcall.cc
-+++ b/gcc/tree-tailcall.cc
-@@ -206,14 +206,48 @@ suitable_for_tail_call_opt_p (gcall *call, bool diag_musttail)
- 
-   /* ??? It is OK if the argument of a function is taken in some cases,
-      but not in all cases.  See PR15387 and PR19616.  Revisit for 4.1.  */
--  for (param = DECL_ARGUMENTS (current_function_decl);
--       param;
--       param = DECL_CHAIN (param))
--    if (TREE_ADDRESSABLE (param))
-+  if (!diag_musttail || !gimple_call_must_tail_p (call))
-+    for (param = DECL_ARGUMENTS (current_function_decl);
-+	 param; param = DECL_CHAIN (param))
-+      if (TREE_ADDRESSABLE (param))
-+	{
-+	  maybe_error_musttail (call, _("address of caller arguments taken"),
-+				diag_musttail);
-+	  return false;
-+	}
-+
-+  if (diag_musttail
-+      && gimple_call_must_tail_p (call)
-+      && warn_musttail_local_addr)
-+    for (unsigned int i = 0; i < gimple_call_num_args (call); i++)
-       {
--	maybe_error_musttail (call, _("address of caller arguments taken"),
--			      diag_musttail);
--	return false;
-+	tree arg = gimple_call_arg (call, i);
-+	if (!POINTER_TYPE_P (TREE_TYPE (arg)))
-+	  continue;
-+	if (TREE_CODE (arg) == ADDR_EXPR)
-+	  {
-+	    arg = get_base_address (TREE_OPERAND (arg, 0));
-+	    if (auto_var_in_fn_p (arg, current_function_decl))
-+	      {
-+		if (TREE_CODE (arg) == LABEL_DECL)
-+		  warning_at (gimple_location (call), OPT_Wmusttail_local_addr,
-+			      "address of label passed to %<musttail%> "
-+			      "call argument");
-+		else if (TREE_CODE (arg) == PARM_DECL)
-+		  warning_at (gimple_location (call), OPT_Wmusttail_local_addr,
-+			      "address of parameter %qD passed to "
-+			      "%<musttail%> call argument", arg);
-+		else if (!DECL_ARTIFICIAL (arg) && DECL_NAME (arg))
-+		  warning_at (gimple_location (call), OPT_Wmusttail_local_addr,
-+			      "address of automatic variable %qD passed to "
-+			      "%<musttail%> call argument", arg);
-+		else
-+		  warning_at (gimple_location (call), OPT_Wmusttail_local_addr,
-+			      "address of local variable passed to "
-+			      "%<musttail%> call argument");
-+		suppress_warning (call, OPT_Wmaybe_musttail_local_addr);
-+	      }
-+	  }
-       }
- 
-   return true;
-@@ -443,7 +477,7 @@ maybe_error_musttail (gcall *call, const char *err, bool diag_musttail)
- {
-   if (gimple_call_must_tail_p (call) && diag_musttail)
-     {
--      error_at (call->location, "cannot tail-call: %s", err);
-+      error_at (gimple_location (call), "cannot tail-call: %s", err);
-       /* Avoid another error. ??? If there are multiple reasons why tail
- 	 calls fail it might be useful to report them all to avoid
- 	 whack-a-mole for the user. But currently there is too much
-@@ -728,6 +762,19 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
- 	{
- 	  if (!VAR_P (var))
- 	    {
-+	      if (diag_musttail && gimple_call_must_tail_p (call))
-+		{
-+		  auto opt = OPT_Wmaybe_musttail_local_addr;
-+		  if (!warning_suppressed_p (call,
-+					     opt))
-+		    {
-+		      warning_at (gimple_location (call), opt,
-+				  "address of local variable can escape to "
-+				  "%<musttail%> call");
-+		      suppress_warning (call, opt);
-+		    }
-+		  continue;
-+		}
- 	      if (local_live_vars)
- 		BITMAP_FREE (local_live_vars);
- 	      maybe_error_musttail (call,
-@@ -740,6 +787,24 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
- 	      unsigned int *v = live_vars->get (DECL_UID (var));
- 	      if (bitmap_bit_p (local_live_vars, *v))
- 		{
-+		  if (diag_musttail && gimple_call_must_tail_p (call))
-+		    {
-+		      auto opt = OPT_Wmaybe_musttail_local_addr;
-+		      if (!warning_suppressed_p (call, opt))
-+			{
-+			  if (!DECL_ARTIFICIAL (var) && DECL_NAME (var))
-+			    warning_at (gimple_location (call), opt,
-+					"address of automatic variable %qD "
-+					"can escape to %<musttail%> call",
-+					var);
-+			  else
-+			    warning_at (gimple_location (call), opt,
-+					"address of local variable can escape "
-+					"to %<musttail%> call");
-+			  suppress_warning (call, opt);
-+			}
-+		      continue;
-+		    }
- 		  BITMAP_FREE (local_live_vars);
- 		  maybe_error_musttail (call,
- 					_("call invocation refers to locals"),
-@@ -749,6 +814,22 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
- 	    }
- 	}
-     }
-+  if (diag_musttail
-+      && gimple_call_must_tail_p (call)
-+      && !warning_suppressed_p (call, OPT_Wmaybe_musttail_local_addr))
-+    for (tree param = DECL_ARGUMENTS (current_function_decl);
-+	 param; param = DECL_CHAIN (param))
-+      if (may_be_aliased (param)
-+	  && (ref_maybe_used_by_stmt_p (call, param, false)
-+	      || call_may_clobber_ref_p (call, param, false)))
-+	{
-+	  auto opt = OPT_Wmaybe_musttail_local_addr;
-+	  warning_at (gimple_location (call), opt,
-+		      "address of parameter %qD can escape to "
-+		      "%<musttail%> call", param);
-+	  suppress_warning (call, opt);
-+	  break;
-+	}
- 
-   if (local_live_vars)
-     BITMAP_FREE (local_live_vars);
-
-base-commit: eb26b667518c951d06f3c51118a1d41dcdda8b99
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch b/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch
index 339ba64..1873a71 100644
--- a/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch
+++ b/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch
@@ -1,20 +1,22 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c4
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
 
 2025-04-01  Jakub Jelinek  <jakub@redhat.com>
 
 	PR tree-optimization/119491
-	* tree-tailcall.cc (independent_of_stmt_p): Use
-	find_fallthru_edge (bb->succs)->dest instead of single_succ (bb).
+	* tree-tailcall.cc (single_non_eh_succ_edge): New function.
+	(independent_of_stmt_p): Use single_non_eh_succ_edge (bb)->dest
+	instead of single_succ (bb).
 	(empty_eh_cleanup): New function.
 	(find_tail_calls): Diagnose throwing of exceptions which do not
 	propagate only if there are no EDGE_EH successor edges.  If there are
 	and the call is musttail, use empty_eh_cleanup to find if the cleanup
 	is not empty.  If not or the call is not musttail, use different
 	diagnostics.  Set is_noreturn even if there are successor edges.  Use
-	find_fallthru_edge (abb->succs) instead of single_succ_edge (abb).
+	single_non_eh_succ_edge (abb) instead of single_succ_edge (abb).  Punt
+	on internal noreturn calls.
 	(decrease_profile): Don't assert 0 or 1 successor edges.
 	(eliminate_tail_call): Use
-	find_fallthru_edge (gsi_bb (t->call_gsi)->succs) instead of
+	single_non_eh_succ_edge (gsi_bb (t->call_gsi)) instead of
 	single_succ_edge (gsi_bb (t->call_gsi)).
 	(tree_optimize_tail_calls_1): Also look into basic blocks with
 	single succ edge which is EDGE_EH for noreturn musttail calls.
@@ -22,164 +24,52 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c4
 	* g++.dg/opt/musttail3.C: New test.
 	* g++.dg/opt/musttail4.C: New test.
 	* g++.dg/opt/musttail5.C: New test.
-diff --git a/gcc/testsuite/g++.dg/opt/musttail3.C b/gcc/testsuite/g++.dg/opt/musttail3.C
-new file mode 100644
-index 000000000000..1c4e54952b1e
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/opt/musttail3.C
-@@ -0,0 +1,41 @@
-+// PR tree-optimization/119491
-+// { dg-do compile { target { external_musttail && c++11 } } }
-+// { dg-options "-O2" }
-+
-+struct A {
-+  struct B {};
-+  A () {}
-+};
-+void qux ();
-+unsigned char v;
-+A w;
-+void foo (A);
-+
-+template <typename T>
-+[[gnu::always_inline]] static inline void
-+bar (int &)
-+{
-+}
-+
-+[[gnu::always_inline]] static inline void
-+baz (int *)
-+{
-+  int r = 0;
-+  bar<int> (r);
-+}
-+
-+[[gnu::always_inline]] inline void
-+corge (A)
-+{
-+  if (v)
-+    qux ();
-+  [[gnu::musttail]] return foo (w);
-+}
-+
-+void
-+freddy (A)
-+{
-+  int t;
-+  baz (&t);
-+  [[gnu::musttail]] return corge (A{});
-+}
-diff --git a/gcc/testsuite/g++.dg/opt/musttail4.C b/gcc/testsuite/g++.dg/opt/musttail4.C
-new file mode 100644
-index 000000000000..ede2959f7d74
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/opt/musttail4.C
-@@ -0,0 +1,35 @@
-+// { dg-do compile { target { external_musttail && c++11 } } }
-+// { dg-options "-O2 -fexceptions" }
-+
-+struct S { ~S (); };
-+volatile int v;
-+struct T { ~T () { v = v + 1; } };
-+struct U { ~U () {} };
-+int foo ();
-+
-+int
-+bar () noexcept
-+{
-+  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: call may throw exception that does not propagate" }
-+}
-+
-+int
-+baz ()
-+{
-+  S s;
-+  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: other reasons" }
-+}
-+
-+int
-+qux ()
-+{
-+  T t;
-+  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: other reasons" }
-+}
-+
-+int
-+corge ()
-+{
-+  U u;
-+  [[gnu::musttail]] return foo ();
-+}
-diff --git a/gcc/testsuite/g++.dg/opt/musttail5.C b/gcc/testsuite/g++.dg/opt/musttail5.C
-new file mode 100644
-index 000000000000..604dd6907aa9
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/opt/musttail5.C
-@@ -0,0 +1,41 @@
-+// PR tree-optimization/119491
-+// { dg-do compile { target { external_musttail && c++11 } } }
-+// { dg-options "-O2" }
-+
-+struct A {
-+  struct B {};
-+  A () {}
-+};
-+void qux ();
-+unsigned char v;
-+A w;
-+[[noreturn]] void foo (A);
-+
-+template <typename T>
-+[[gnu::always_inline]] static inline void
-+bar (int &)
-+{
-+}
-+
-+[[gnu::always_inline]] static inline void
-+baz (int *)
-+{
-+  int r = 0;
-+  bar<int> (r);
-+}
+
+--- a/gcc/tree-tailcall.cc	2025-04-01 16:47:30.373502796 +0200
++++ b/gcc/tree-tailcall.cc	2025-04-02 09:02:35.572760732 +0200
+@@ -219,6 +219,23 @@ suitable_for_tail_call_opt_p (gcall *cal
+   return true;
+ }
+ 
++/* Return single successor edge ignoring EDGE_EH edges.  */
 +
-+[[gnu::always_inline]] inline void
-+corge (A)
++static edge
++single_non_eh_succ_edge (basic_block bb)
 +{
-+  if (v)
-+    qux ();
-+  [[gnu::musttail]] return foo (w);
++   edge e, ret = NULL;
++   edge_iterator ei;
++   FOR_EACH_EDGE (e, ei, bb->succs)
++    if ((e->flags & EDGE_EH) == 0)
++      {
++	gcc_assert (ret == NULL);
++	ret = e;
++      }
++  gcc_assert (ret);
++  return ret;
 +}
 +
-+void
-+freddy (A)
-+{
-+  int t;
-+  baz (&t);
-+  [[gnu::musttail]] return corge (A{});
-+}
-diff --git a/gcc/tree-tailcall.cc b/gcc/tree-tailcall.cc
-index e71341bfb2bc..b910dce7acbd 100644
---- a/gcc/tree-tailcall.cc
-+++ b/gcc/tree-tailcall.cc
-@@ -245,7 +245,7 @@ independent_of_stmt_p (tree expr, gimple *at, gimple_stmt_iterator gsi,
+ /* Checks whether the expression EXPR in stmt AT is independent of the
+    statement pointed to by GSI (in a sense that we already know EXPR's value
+    at GSI).  We use the fact that we are only called from the chain of
+@@ -245,7 +262,7 @@ independent_of_stmt_p (tree expr, gimple
    /* Mark the blocks in the chain leading to the end.  */
    at_bb = gimple_bb (at);
    call_bb = gimple_bb (gsi_stmt (gsi));
 -  for (bb = call_bb; bb != at_bb; bb = single_succ (bb))
-+  for (bb = call_bb; bb != at_bb; bb = find_fallthru_edge (bb->succs)->dest)
++  for (bb = call_bb; bb != at_bb; bb = single_non_eh_succ_edge (bb)->dest)
      bb->aux = &bb->aux;
    bb->aux = &bb->aux;
  
-@@ -289,7 +289,7 @@ independent_of_stmt_p (tree expr, gimple *at, gimple_stmt_iterator gsi,
+@@ -289,7 +306,7 @@ independent_of_stmt_p (tree expr, gimple
      }
  
    /* Unmark the blocks.  */
 -  for (bb = call_bb; bb != at_bb; bb = single_succ (bb))
-+  for (bb = call_bb; bb != at_bb; bb = find_fallthru_edge (bb->succs)->dest)
++  for (bb = call_bb; bb != at_bb; bb = single_non_eh_succ_edge (bb)->dest)
      bb->aux = NULL;
    bb->aux = NULL;
  
-@@ -462,6 +462,33 @@ maybe_error_musttail (gcall *call, const char *err, bool diag_musttail)
+@@ -462,6 +479,33 @@ maybe_error_musttail (gcall *call, const
      }
  }
  
@@ -213,7 +103,7 @@ index e71341bfb2bc..b910dce7acbd 100644
  /* Argument for compute_live_vars/live_vars_at_stmt and what compute_live_vars
     returns.  Computed lazily, but just once for the function.  */
  static live_vars_map *live_vars;
-@@ -612,14 +639,35 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
+@@ -612,14 +656,36 @@ find_tail_calls (basic_block bb, struct
    if ((stmt_could_throw_p (cfun, stmt)
         && !stmt_can_throw_external (cfun, stmt)) || EDGE_COUNT (bb->succs) > 1)
    {
@@ -247,7 +137,8 @@ index e71341bfb2bc..b910dce7acbd 100644
 +      }
 +
 +    if (!gimple_call_must_tail_p (call)
-+	|| !empty_eh_cleanup (e->dest, 20))
++	|| !empty_eh_cleanup (e->dest, 20)
++	|| EDGE_COUNT (bb->succs) > 2)
 +      {
 +	maybe_error_musttail (call,
 +			      _("call may throw exception caught locally "
@@ -257,7 +148,7 @@ index e71341bfb2bc..b910dce7acbd 100644
    }
  
    /* If the function returns a value, then at present, the tail call
-@@ -763,8 +811,7 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
+@@ -763,8 +829,7 @@ find_tail_calls (basic_block bb, struct
    a = NULL_TREE;
    auto_bitmap to_move_defs;
    auto_vec<gimple *> to_move_stmts;
@@ -267,19 +158,31 @@ index e71341bfb2bc..b910dce7acbd 100644
  
    abb = bb;
    agsi = gsi;
-@@ -776,8 +823,9 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
+@@ -776,8 +841,9 @@ find_tail_calls (basic_block bb, struct
  
        while (gsi_end_p (agsi))
  	{
 -	  ass_var = propagate_through_phis (ass_var, single_succ_edge (abb));
 -	  abb = single_succ (abb);
-+	  edge e = find_fallthru_edge (abb->succs);
++	  edge e = single_non_eh_succ_edge (abb);
 +	  ass_var = propagate_through_phis (ass_var, e);
 +	  abb = e->dest;
  	  agsi = gsi_start_bb (abb);
  	}
  
-@@ -1112,11 +1160,6 @@ static void
+@@ -851,6 +917,11 @@ find_tail_calls (basic_block bb, struct
+   /* See if this is a tail call we can handle.  */
+   if (is_noreturn)
+     {
++      if (gimple_call_internal_p (call))
++	{
++	  maybe_error_musttail (call, _("internal call"), diag_musttail);
++	  return;
++	}
+       tree rettype = TREE_TYPE (TREE_TYPE (current_function_decl));
+       tree calltype = TREE_TYPE (gimple_call_fntype (call));
+       if (!VOID_TYPE_P (rettype)
+@@ -1112,11 +1183,6 @@ static void
  decrease_profile (basic_block bb, profile_count count)
  {
    bb->count = bb->count - count;
@@ -291,16 +194,16 @@ index e71341bfb2bc..b910dce7acbd 100644
  }
  
  /* Eliminates tail call described by T.  TMP_VARS is a list of
-@@ -1181,7 +1224,7 @@ eliminate_tail_call (struct tailcall *t, class loop *&new_loop)
+@@ -1181,7 +1247,7 @@ eliminate_tail_call (struct tailcall *t,
    else
      {
        /* Number of executions of function has reduced by the tailcall.  */
 -      e = single_succ_edge (gsi_bb (t->call_gsi));
-+      e = find_fallthru_edge (gsi_bb (t->call_gsi)->succs);
++      e = single_non_eh_succ_edge (gsi_bb (t->call_gsi));
  
        profile_count count = e->count ();
  
-@@ -1196,8 +1239,7 @@ eliminate_tail_call (struct tailcall *t, class loop *&new_loop)
+@@ -1196,8 +1262,7 @@ eliminate_tail_call (struct tailcall *t,
  	decrease_profile (e->dest, count);
  
        /* Replace the call by a jump to the start of function.  */
@@ -310,7 +213,7 @@ index e71341bfb2bc..b910dce7acbd 100644
      }
    gcc_assert (e);
    PENDING_STMT (e) = NULL;
-@@ -1362,7 +1404,9 @@ tree_optimize_tail_calls_1 (bool opt_tailcalls, bool only_musttail,
+@@ -1362,7 +1427,9 @@ tree_optimize_tail_calls_1 (bool opt_tai
      {
        basic_block bb;
        FOR_EACH_BB_FN (bb, cfun)
@@ -321,3 +224,129 @@ index e71341bfb2bc..b910dce7acbd 100644
  	  if (gimple *c = last_nondebug_stmt (bb))
  	    if (is_gimple_call (c)
  		&& gimple_call_must_tail_p (as_a <gcall *> (c))
+--- a/gcc/testsuite/g++.dg/opt/musttail3.C	2025-04-01 18:47:10.474945080 +0200
++++ b/gcc/testsuite/g++.dg/opt/musttail3.C	2025-04-01 18:49:27.063068029 +0200
+@@ -0,0 +1,41 @@
++// PR tree-optimization/119491
++// { dg-do compile { target { external_musttail && c++11 } } }
++// { dg-options "-O2" }
++
++struct A {
++  struct B {};
++  A () {}
++};
++void qux ();
++unsigned char v;
++A w;
++void foo (A);
++
++template <typename T>
++[[gnu::always_inline]] static inline void
++bar (int &)
++{
++}
++
++[[gnu::always_inline]] static inline void
++baz (int *)
++{
++  int r = 0;
++  bar<int> (r);
++}
++
++[[gnu::always_inline]] inline void
++corge (A)
++{
++  if (v)
++    qux ();
++  [[gnu::musttail]] return foo (w);
++}
++
++void
++freddy (A)
++{
++  int t;
++  baz (&t);
++  [[gnu::musttail]] return corge (A{});
++}
+--- a/gcc/testsuite/g++.dg/opt/musttail4.C	2025-04-01 19:10:56.389350911 +0200
++++ b/gcc/testsuite/g++.dg/opt/musttail4.C	2025-04-01 19:28:18.285020409 +0200
+@@ -0,0 +1,35 @@
++// { dg-do compile { target { external_musttail && c++11 } } }
++// { dg-options "-O2 -fexceptions" }
++
++struct S { ~S (); };
++volatile int v;
++struct T { ~T () { v = v + 1; } };
++struct U { ~U () {} };
++int foo ();
++
++int
++bar () noexcept
++{
++  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: call may throw exception that does not propagate" }
++}
++
++int
++baz ()
++{
++  S s;
++  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: other reasons" }
++}
++
++int
++qux ()
++{
++  T t;
++  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: other reasons" }
++}
++
++int
++corge ()
++{
++  U u;
++  [[gnu::musttail]] return foo ();
++}
+--- a/gcc/testsuite/g++.dg/opt/musttail5.C	2025-04-01 19:14:50.981127712 +0200
++++ b/gcc/testsuite/g++.dg/opt/musttail5.C	2025-04-01 19:11:25.249954382 +0200
+@@ -0,0 +1,41 @@
++// PR tree-optimization/119491
++// { dg-do compile { target { external_musttail && c++11 } } }
++// { dg-options "-O2" }
++
++struct A {
++  struct B {};
++  A () {}
++};
++void qux ();
++unsigned char v;
++A w;
++[[noreturn]] void foo (A);
++
++template <typename T>
++[[gnu::always_inline]] static inline void
++bar (int &)
++{
++}
++
++[[gnu::always_inline]] static inline void
++baz (int *)
++{
++  int r = 0;
++  bar<int> (r);
++}
++
++[[gnu::always_inline]] inline void
++corge (A)
++{
++  if (v)
++    qux ();
++  [[gnu::musttail]] return foo (w);
++}
++
++void
++freddy (A)
++{
++  int t;
++  baz (&t);
++  [[gnu::musttail]] return corge (A{});
++}
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index b497164..8223363 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 51	????
 
+	- 80_all_PR119376-tailc-Don-t-fail-musttail-calls-if-they-use-or-could.patch
 	+ 82_all_PR119318-ipa-cp.patch
 	+ 83_all_PR119491-tailcall-eh.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-02 16:14 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-02 16:14 UTC (permalink / raw
  To: gentoo-commits
commit:     e4168bed2ceeb5eb7240f82a0135a61dcf777da8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  2 16:14:11 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr  2 16:14:11 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=e4168bed
15.0.0: refresh 83_all_PR119491-tailcall-eh.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch | 341 ++++++++++++++----------
 1 file changed, 199 insertions(+), 142 deletions(-)
diff --git a/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch b/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch
index 1873a71..040d2f8 100644
--- a/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch
+++ b/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch
@@ -1,6 +1,38 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
+https://inbox.sourceware.org/gcc-patches/Z+1hCrznhv68Sv4J@tucnak/
 
-2025-04-01  Jakub Jelinek  <jakub@redhat.com>
+From e561af4c75ca62ae9363700531e60cc5793a88b3 Mon Sep 17 00:00:00 2001
+Message-ID: <e561af4c75ca62ae9363700531e60cc5793a88b3.1743610408.git.sam@gentoo.org>
+From: Jakub Jelinek <jakub@redhat.com>
+Date: Wed, 2 Apr 2025 18:08:42 +0200
+Subject: [PATCH] tailc: Deal with trivially useless EH cleanups [PR119491]
+
+Hi!
+
+The following testcases FAIL, because EH cleanup is performed only before
+IPA and then right before musttail pass.
+At -O2 etc. (except for -O0/-Og) we handle musttail calls in the tailc
+pass though, and we can fail at that point because the calls might appear
+to throw internal exceptions which just don't do anything interesting
+(perhaps have debug statements or clobber statements in them) before they
+continue with resume of the exception (i.e. throw it externally).
+
+As Richi said in the PR (and I agree) that moving passes is risky at this
+point, the following patch instead teaches the tail{r,c} and musttail
+passes to deal with such extra EDGE_EH edges.
+
+It is fairly simple thing, if we see an EDGE_EH edge from the call we
+just look up where it lands and if there are no
+non-debug/non-clobber/non-label statements before resx which throws
+externally, such edge can be ignored for tail call optimization or
+tail recursion.  At other spots I just need to avoid using
+single_succ/single_succ_edge because the bb might have another edge -
+EDGE_EH.
+
+To make this less risky, this is done solely for the musttail calls for now.
+
+Bootstrapped/regtested on x86_64-linux and i686-linux, ok for trunk?
+
+2025-04-02  Jakub Jelinek  <jakub@redhat.com>
 
 	PR tree-optimization/119491
 	* tree-tailcall.cc (single_non_eh_succ_edge): New function.
@@ -24,10 +56,156 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
 	* g++.dg/opt/musttail3.C: New test.
 	* g++.dg/opt/musttail4.C: New test.
 	* g++.dg/opt/musttail5.C: New test.
+---
+ gcc/testsuite/g++.dg/opt/musttail3.C |  41 ++++++++++
+ gcc/testsuite/g++.dg/opt/musttail4.C |  35 +++++++++
+ gcc/testsuite/g++.dg/opt/musttail5.C |  41 ++++++++++
+ gcc/tree-tailcall.cc                 | 113 +++++++++++++++++++++------
+ 4 files changed, 207 insertions(+), 23 deletions(-)
+ create mode 100644 gcc/testsuite/g++.dg/opt/musttail3.C
+ create mode 100644 gcc/testsuite/g++.dg/opt/musttail4.C
+ create mode 100644 gcc/testsuite/g++.dg/opt/musttail5.C
 
---- a/gcc/tree-tailcall.cc	2025-04-01 16:47:30.373502796 +0200
-+++ b/gcc/tree-tailcall.cc	2025-04-02 09:02:35.572760732 +0200
-@@ -219,6 +219,23 @@ suitable_for_tail_call_opt_p (gcall *cal
+diff --git a/gcc/testsuite/g++.dg/opt/musttail3.C b/gcc/testsuite/g++.dg/opt/musttail3.C
+new file mode 100644
+index 000000000000..1c4e54952b1e
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/opt/musttail3.C
+@@ -0,0 +1,41 @@
++// PR tree-optimization/119491
++// { dg-do compile { target { external_musttail && c++11 } } }
++// { dg-options "-O2" }
++
++struct A {
++  struct B {};
++  A () {}
++};
++void qux ();
++unsigned char v;
++A w;
++void foo (A);
++
++template <typename T>
++[[gnu::always_inline]] static inline void
++bar (int &)
++{
++}
++
++[[gnu::always_inline]] static inline void
++baz (int *)
++{
++  int r = 0;
++  bar<int> (r);
++}
++
++[[gnu::always_inline]] inline void
++corge (A)
++{
++  if (v)
++    qux ();
++  [[gnu::musttail]] return foo (w);
++}
++
++void
++freddy (A)
++{
++  int t;
++  baz (&t);
++  [[gnu::musttail]] return corge (A{});
++}
+diff --git a/gcc/testsuite/g++.dg/opt/musttail4.C b/gcc/testsuite/g++.dg/opt/musttail4.C
+new file mode 100644
+index 000000000000..ede2959f7d74
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/opt/musttail4.C
+@@ -0,0 +1,35 @@
++// { dg-do compile { target { external_musttail && c++11 } } }
++// { dg-options "-O2 -fexceptions" }
++
++struct S { ~S (); };
++volatile int v;
++struct T { ~T () { v = v + 1; } };
++struct U { ~U () {} };
++int foo ();
++
++int
++bar () noexcept
++{
++  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: call may throw exception that does not propagate" }
++}
++
++int
++baz ()
++{
++  S s;
++  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: other reasons" }
++}
++
++int
++qux ()
++{
++  T t;
++  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: other reasons" }
++}
++
++int
++corge ()
++{
++  U u;
++  [[gnu::musttail]] return foo ();
++}
+diff --git a/gcc/testsuite/g++.dg/opt/musttail5.C b/gcc/testsuite/g++.dg/opt/musttail5.C
+new file mode 100644
+index 000000000000..604dd6907aa9
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/opt/musttail5.C
+@@ -0,0 +1,41 @@
++// PR tree-optimization/119491
++// { dg-do compile { target { external_musttail && c++11 } } }
++// { dg-options "-O2" }
++
++struct A {
++  struct B {};
++  A () {}
++};
++void qux ();
++unsigned char v;
++A w;
++[[noreturn]] void foo (A);
++
++template <typename T>
++[[gnu::always_inline]] static inline void
++bar (int &)
++{
++}
++
++[[gnu::always_inline]] static inline void
++baz (int *)
++{
++  int r = 0;
++  bar<int> (r);
++}
++
++[[gnu::always_inline]] inline void
++corge (A)
++{
++  if (v)
++    qux ();
++  [[gnu::musttail]] return foo (w);
++}
++
++void
++freddy (A)
++{
++  int t;
++  baz (&t);
++  [[gnu::musttail]] return corge (A{});
++}
+diff --git a/gcc/tree-tailcall.cc b/gcc/tree-tailcall.cc
+index 374be2ae6a75..477729ca2137 100644
+--- a/gcc/tree-tailcall.cc
++++ b/gcc/tree-tailcall.cc
+@@ -253,6 +253,23 @@ suitable_for_tail_call_opt_p (gcall *call, bool diag_musttail)
    return true;
  }
  
@@ -51,7 +229,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
  /* Checks whether the expression EXPR in stmt AT is independent of the
     statement pointed to by GSI (in a sense that we already know EXPR's value
     at GSI).  We use the fact that we are only called from the chain of
-@@ -245,7 +262,7 @@ independent_of_stmt_p (tree expr, gimple
+@@ -279,7 +296,7 @@ independent_of_stmt_p (tree expr, gimple *at, gimple_stmt_iterator gsi,
    /* Mark the blocks in the chain leading to the end.  */
    at_bb = gimple_bb (at);
    call_bb = gimple_bb (gsi_stmt (gsi));
@@ -60,7 +238,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
      bb->aux = &bb->aux;
    bb->aux = &bb->aux;
  
-@@ -289,7 +306,7 @@ independent_of_stmt_p (tree expr, gimple
+@@ -323,7 +340,7 @@ independent_of_stmt_p (tree expr, gimple *at, gimple_stmt_iterator gsi,
      }
  
    /* Unmark the blocks.  */
@@ -69,7 +247,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
      bb->aux = NULL;
    bb->aux = NULL;
  
-@@ -462,6 +479,33 @@ maybe_error_musttail (gcall *call, const
+@@ -496,6 +513,33 @@ maybe_error_musttail (gcall *call, const char *err, bool diag_musttail)
      }
  }
  
@@ -103,7 +281,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
  /* Argument for compute_live_vars/live_vars_at_stmt and what compute_live_vars
     returns.  Computed lazily, but just once for the function.  */
  static live_vars_map *live_vars;
-@@ -612,14 +656,36 @@ find_tail_calls (basic_block bb, struct
+@@ -646,14 +690,36 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
    if ((stmt_could_throw_p (cfun, stmt)
         && !stmt_can_throw_external (cfun, stmt)) || EDGE_COUNT (bb->succs) > 1)
    {
@@ -148,7 +326,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
    }
  
    /* If the function returns a value, then at present, the tail call
-@@ -763,8 +829,7 @@ find_tail_calls (basic_block bb, struct
+@@ -844,8 +910,7 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
    a = NULL_TREE;
    auto_bitmap to_move_defs;
    auto_vec<gimple *> to_move_stmts;
@@ -158,7 +336,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
  
    abb = bb;
    agsi = gsi;
-@@ -776,8 +841,9 @@ find_tail_calls (basic_block bb, struct
+@@ -857,8 +922,9 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
  
        while (gsi_end_p (agsi))
  	{
@@ -170,7 +348,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
  	  agsi = gsi_start_bb (abb);
  	}
  
-@@ -851,6 +917,11 @@ find_tail_calls (basic_block bb, struct
+@@ -932,6 +998,11 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
    /* See if this is a tail call we can handle.  */
    if (is_noreturn)
      {
@@ -182,7 +360,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
        tree rettype = TREE_TYPE (TREE_TYPE (current_function_decl));
        tree calltype = TREE_TYPE (gimple_call_fntype (call));
        if (!VOID_TYPE_P (rettype)
-@@ -1112,11 +1183,6 @@ static void
+@@ -1193,11 +1264,6 @@ static void
  decrease_profile (basic_block bb, profile_count count)
  {
    bb->count = bb->count - count;
@@ -194,7 +372,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
  }
  
  /* Eliminates tail call described by T.  TMP_VARS is a list of
-@@ -1181,7 +1247,7 @@ eliminate_tail_call (struct tailcall *t,
+@@ -1262,7 +1328,7 @@ eliminate_tail_call (struct tailcall *t, class loop *&new_loop)
    else
      {
        /* Number of executions of function has reduced by the tailcall.  */
@@ -203,7 +381,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
  
        profile_count count = e->count ();
  
-@@ -1196,8 +1262,7 @@ eliminate_tail_call (struct tailcall *t,
+@@ -1277,8 +1343,7 @@ eliminate_tail_call (struct tailcall *t, class loop *&new_loop)
  	decrease_profile (e->dest, count);
  
        /* Replace the call by a jump to the start of function.  */
@@ -213,7 +391,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
      }
    gcc_assert (e);
    PENDING_STMT (e) = NULL;
-@@ -1362,7 +1427,9 @@ tree_optimize_tail_calls_1 (bool opt_tai
+@@ -1443,7 +1508,9 @@ tree_optimize_tail_calls_1 (bool opt_tailcalls, bool only_musttail,
      {
        basic_block bb;
        FOR_EACH_BB_FN (bb, cfun)
@@ -224,129 +402,8 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119491#c5
  	  if (gimple *c = last_nondebug_stmt (bb))
  	    if (is_gimple_call (c)
  		&& gimple_call_must_tail_p (as_a <gcall *> (c))
---- a/gcc/testsuite/g++.dg/opt/musttail3.C	2025-04-01 18:47:10.474945080 +0200
-+++ b/gcc/testsuite/g++.dg/opt/musttail3.C	2025-04-01 18:49:27.063068029 +0200
-@@ -0,0 +1,41 @@
-+// PR tree-optimization/119491
-+// { dg-do compile { target { external_musttail && c++11 } } }
-+// { dg-options "-O2" }
-+
-+struct A {
-+  struct B {};
-+  A () {}
-+};
-+void qux ();
-+unsigned char v;
-+A w;
-+void foo (A);
-+
-+template <typename T>
-+[[gnu::always_inline]] static inline void
-+bar (int &)
-+{
-+}
-+
-+[[gnu::always_inline]] static inline void
-+baz (int *)
-+{
-+  int r = 0;
-+  bar<int> (r);
-+}
-+
-+[[gnu::always_inline]] inline void
-+corge (A)
-+{
-+  if (v)
-+    qux ();
-+  [[gnu::musttail]] return foo (w);
-+}
-+
-+void
-+freddy (A)
-+{
-+  int t;
-+  baz (&t);
-+  [[gnu::musttail]] return corge (A{});
-+}
---- a/gcc/testsuite/g++.dg/opt/musttail4.C	2025-04-01 19:10:56.389350911 +0200
-+++ b/gcc/testsuite/g++.dg/opt/musttail4.C	2025-04-01 19:28:18.285020409 +0200
-@@ -0,0 +1,35 @@
-+// { dg-do compile { target { external_musttail && c++11 } } }
-+// { dg-options "-O2 -fexceptions" }
-+
-+struct S { ~S (); };
-+volatile int v;
-+struct T { ~T () { v = v + 1; } };
-+struct U { ~U () {} };
-+int foo ();
-+
-+int
-+bar () noexcept
-+{
-+  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: call may throw exception that does not propagate" }
-+}
-+
-+int
-+baz ()
-+{
-+  S s;
-+  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: other reasons" }
-+}
-+
-+int
-+qux ()
-+{
-+  T t;
-+  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: other reasons" }
-+}
-+
-+int
-+corge ()
-+{
-+  U u;
-+  [[gnu::musttail]] return foo ();
-+}
---- a/gcc/testsuite/g++.dg/opt/musttail5.C	2025-04-01 19:14:50.981127712 +0200
-+++ b/gcc/testsuite/g++.dg/opt/musttail5.C	2025-04-01 19:11:25.249954382 +0200
-@@ -0,0 +1,41 @@
-+// PR tree-optimization/119491
-+// { dg-do compile { target { external_musttail && c++11 } } }
-+// { dg-options "-O2" }
-+
-+struct A {
-+  struct B {};
-+  A () {}
-+};
-+void qux ();
-+unsigned char v;
-+A w;
-+[[noreturn]] void foo (A);
-+
-+template <typename T>
-+[[gnu::always_inline]] static inline void
-+bar (int &)
-+{
-+}
-+
-+[[gnu::always_inline]] static inline void
-+baz (int *)
-+{
-+  int r = 0;
-+  bar<int> (r);
-+}
-+
-+[[gnu::always_inline]] inline void
-+corge (A)
-+{
-+  if (v)
-+    qux ();
-+  [[gnu::musttail]] return foo (w);
-+}
-+
-+void
-+freddy (A)
-+{
-+  int t;
-+  baz (&t);
-+  [[gnu::musttail]] return corge (A{});
-+}
+
+base-commit: aca8155c09001f269a20d6df438fa0e749dd5388
+-- 
+2.49.0
+
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-02 18:03 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-02 18:03 UTC (permalink / raw
  To: gentoo-commits
commit:     2f4f4f1d4b8134456c4a5e23607a44c59b5dd581
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  2 18:03:43 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr  2 18:03:43 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=2f4f4f1d
15.0.0: drop upstream tailcall eh patch
Just merged.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch | 409 ------------------------
 15.0.0/gentoo/README.history                    |   1 -
 2 files changed, 410 deletions(-)
diff --git a/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch b/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch
deleted file mode 100644
index 040d2f8..0000000
--- a/15.0.0/gentoo/83_all_PR119491-tailcall-eh.patch
+++ /dev/null
@@ -1,409 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/Z+1hCrznhv68Sv4J@tucnak/
-
-From e561af4c75ca62ae9363700531e60cc5793a88b3 Mon Sep 17 00:00:00 2001
-Message-ID: <e561af4c75ca62ae9363700531e60cc5793a88b3.1743610408.git.sam@gentoo.org>
-From: Jakub Jelinek <jakub@redhat.com>
-Date: Wed, 2 Apr 2025 18:08:42 +0200
-Subject: [PATCH] tailc: Deal with trivially useless EH cleanups [PR119491]
-
-Hi!
-
-The following testcases FAIL, because EH cleanup is performed only before
-IPA and then right before musttail pass.
-At -O2 etc. (except for -O0/-Og) we handle musttail calls in the tailc
-pass though, and we can fail at that point because the calls might appear
-to throw internal exceptions which just don't do anything interesting
-(perhaps have debug statements or clobber statements in them) before they
-continue with resume of the exception (i.e. throw it externally).
-
-As Richi said in the PR (and I agree) that moving passes is risky at this
-point, the following patch instead teaches the tail{r,c} and musttail
-passes to deal with such extra EDGE_EH edges.
-
-It is fairly simple thing, if we see an EDGE_EH edge from the call we
-just look up where it lands and if there are no
-non-debug/non-clobber/non-label statements before resx which throws
-externally, such edge can be ignored for tail call optimization or
-tail recursion.  At other spots I just need to avoid using
-single_succ/single_succ_edge because the bb might have another edge -
-EDGE_EH.
-
-To make this less risky, this is done solely for the musttail calls for now.
-
-Bootstrapped/regtested on x86_64-linux and i686-linux, ok for trunk?
-
-2025-04-02  Jakub Jelinek  <jakub@redhat.com>
-
-	PR tree-optimization/119491
-	* tree-tailcall.cc (single_non_eh_succ_edge): New function.
-	(independent_of_stmt_p): Use single_non_eh_succ_edge (bb)->dest
-	instead of single_succ (bb).
-	(empty_eh_cleanup): New function.
-	(find_tail_calls): Diagnose throwing of exceptions which do not
-	propagate only if there are no EDGE_EH successor edges.  If there are
-	and the call is musttail, use empty_eh_cleanup to find if the cleanup
-	is not empty.  If not or the call is not musttail, use different
-	diagnostics.  Set is_noreturn even if there are successor edges.  Use
-	single_non_eh_succ_edge (abb) instead of single_succ_edge (abb).  Punt
-	on internal noreturn calls.
-	(decrease_profile): Don't assert 0 or 1 successor edges.
-	(eliminate_tail_call): Use
-	single_non_eh_succ_edge (gsi_bb (t->call_gsi)) instead of
-	single_succ_edge (gsi_bb (t->call_gsi)).
-	(tree_optimize_tail_calls_1): Also look into basic blocks with
-	single succ edge which is EDGE_EH for noreturn musttail calls.
-
-	* g++.dg/opt/musttail3.C: New test.
-	* g++.dg/opt/musttail4.C: New test.
-	* g++.dg/opt/musttail5.C: New test.
----
- gcc/testsuite/g++.dg/opt/musttail3.C |  41 ++++++++++
- gcc/testsuite/g++.dg/opt/musttail4.C |  35 +++++++++
- gcc/testsuite/g++.dg/opt/musttail5.C |  41 ++++++++++
- gcc/tree-tailcall.cc                 | 113 +++++++++++++++++++++------
- 4 files changed, 207 insertions(+), 23 deletions(-)
- create mode 100644 gcc/testsuite/g++.dg/opt/musttail3.C
- create mode 100644 gcc/testsuite/g++.dg/opt/musttail4.C
- create mode 100644 gcc/testsuite/g++.dg/opt/musttail5.C
-
-diff --git a/gcc/testsuite/g++.dg/opt/musttail3.C b/gcc/testsuite/g++.dg/opt/musttail3.C
-new file mode 100644
-index 000000000000..1c4e54952b1e
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/opt/musttail3.C
-@@ -0,0 +1,41 @@
-+// PR tree-optimization/119491
-+// { dg-do compile { target { external_musttail && c++11 } } }
-+// { dg-options "-O2" }
-+
-+struct A {
-+  struct B {};
-+  A () {}
-+};
-+void qux ();
-+unsigned char v;
-+A w;
-+void foo (A);
-+
-+template <typename T>
-+[[gnu::always_inline]] static inline void
-+bar (int &)
-+{
-+}
-+
-+[[gnu::always_inline]] static inline void
-+baz (int *)
-+{
-+  int r = 0;
-+  bar<int> (r);
-+}
-+
-+[[gnu::always_inline]] inline void
-+corge (A)
-+{
-+  if (v)
-+    qux ();
-+  [[gnu::musttail]] return foo (w);
-+}
-+
-+void
-+freddy (A)
-+{
-+  int t;
-+  baz (&t);
-+  [[gnu::musttail]] return corge (A{});
-+}
-diff --git a/gcc/testsuite/g++.dg/opt/musttail4.C b/gcc/testsuite/g++.dg/opt/musttail4.C
-new file mode 100644
-index 000000000000..ede2959f7d74
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/opt/musttail4.C
-@@ -0,0 +1,35 @@
-+// { dg-do compile { target { external_musttail && c++11 } } }
-+// { dg-options "-O2 -fexceptions" }
-+
-+struct S { ~S (); };
-+volatile int v;
-+struct T { ~T () { v = v + 1; } };
-+struct U { ~U () {} };
-+int foo ();
-+
-+int
-+bar () noexcept
-+{
-+  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: call may throw exception that does not propagate" }
-+}
-+
-+int
-+baz ()
-+{
-+  S s;
-+  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: other reasons" }
-+}
-+
-+int
-+qux ()
-+{
-+  T t;
-+  [[gnu::musttail]] return foo ();	// { dg-error "cannot tail-call: other reasons" }
-+}
-+
-+int
-+corge ()
-+{
-+  U u;
-+  [[gnu::musttail]] return foo ();
-+}
-diff --git a/gcc/testsuite/g++.dg/opt/musttail5.C b/gcc/testsuite/g++.dg/opt/musttail5.C
-new file mode 100644
-index 000000000000..604dd6907aa9
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/opt/musttail5.C
-@@ -0,0 +1,41 @@
-+// PR tree-optimization/119491
-+// { dg-do compile { target { external_musttail && c++11 } } }
-+// { dg-options "-O2" }
-+
-+struct A {
-+  struct B {};
-+  A () {}
-+};
-+void qux ();
-+unsigned char v;
-+A w;
-+[[noreturn]] void foo (A);
-+
-+template <typename T>
-+[[gnu::always_inline]] static inline void
-+bar (int &)
-+{
-+}
-+
-+[[gnu::always_inline]] static inline void
-+baz (int *)
-+{
-+  int r = 0;
-+  bar<int> (r);
-+}
-+
-+[[gnu::always_inline]] inline void
-+corge (A)
-+{
-+  if (v)
-+    qux ();
-+  [[gnu::musttail]] return foo (w);
-+}
-+
-+void
-+freddy (A)
-+{
-+  int t;
-+  baz (&t);
-+  [[gnu::musttail]] return corge (A{});
-+}
-diff --git a/gcc/tree-tailcall.cc b/gcc/tree-tailcall.cc
-index 374be2ae6a75..477729ca2137 100644
---- a/gcc/tree-tailcall.cc
-+++ b/gcc/tree-tailcall.cc
-@@ -253,6 +253,23 @@ suitable_for_tail_call_opt_p (gcall *call, bool diag_musttail)
-   return true;
- }
- 
-+/* Return single successor edge ignoring EDGE_EH edges.  */
-+
-+static edge
-+single_non_eh_succ_edge (basic_block bb)
-+{
-+   edge e, ret = NULL;
-+   edge_iterator ei;
-+   FOR_EACH_EDGE (e, ei, bb->succs)
-+    if ((e->flags & EDGE_EH) == 0)
-+      {
-+	gcc_assert (ret == NULL);
-+	ret = e;
-+      }
-+  gcc_assert (ret);
-+  return ret;
-+}
-+
- /* Checks whether the expression EXPR in stmt AT is independent of the
-    statement pointed to by GSI (in a sense that we already know EXPR's value
-    at GSI).  We use the fact that we are only called from the chain of
-@@ -279,7 +296,7 @@ independent_of_stmt_p (tree expr, gimple *at, gimple_stmt_iterator gsi,
-   /* Mark the blocks in the chain leading to the end.  */
-   at_bb = gimple_bb (at);
-   call_bb = gimple_bb (gsi_stmt (gsi));
--  for (bb = call_bb; bb != at_bb; bb = single_succ (bb))
-+  for (bb = call_bb; bb != at_bb; bb = single_non_eh_succ_edge (bb)->dest)
-     bb->aux = &bb->aux;
-   bb->aux = &bb->aux;
- 
-@@ -323,7 +340,7 @@ independent_of_stmt_p (tree expr, gimple *at, gimple_stmt_iterator gsi,
-     }
- 
-   /* Unmark the blocks.  */
--  for (bb = call_bb; bb != at_bb; bb = single_succ (bb))
-+  for (bb = call_bb; bb != at_bb; bb = single_non_eh_succ_edge (bb)->dest)
-     bb->aux = NULL;
-   bb->aux = NULL;
- 
-@@ -496,6 +513,33 @@ maybe_error_musttail (gcall *call, const char *err, bool diag_musttail)
-     }
- }
- 
-+/* Return true if there is no real work performed in the exception
-+   path starting at BB and it will in the end result in external exception.
-+   Search at most CNT basic blocks (so that we don't need to do trivial
-+   loop discovery).  */
-+static bool
-+empty_eh_cleanup (basic_block bb, int cnt)
-+{
-+  if (EDGE_COUNT (bb->succs) > 1)
-+    return false;
-+
-+  for (gimple_stmt_iterator gsi = gsi_after_labels (bb); !gsi_end_p (gsi);
-+       gsi_next (&gsi))
-+    {
-+      gimple *g = gsi_stmt (gsi);
-+      if (is_gimple_debug (g) || gimple_clobber_p (g))
-+	continue;
-+      if (is_gimple_resx (g) && stmt_can_throw_external (cfun, g))
-+	return true;
-+      return false;
-+    }
-+  if (!single_succ_p (bb))
-+    return false;
-+  if (cnt == 1)
-+    return false;
-+  return empty_eh_cleanup (single_succ (bb), cnt - 1);
-+}
-+
- /* Argument for compute_live_vars/live_vars_at_stmt and what compute_live_vars
-    returns.  Computed lazily, but just once for the function.  */
- static live_vars_map *live_vars;
-@@ -646,14 +690,36 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
-   if ((stmt_could_throw_p (cfun, stmt)
-        && !stmt_can_throw_external (cfun, stmt)) || EDGE_COUNT (bb->succs) > 1)
-   {
--    if (stmt == last_stmt)
--      maybe_error_musttail (call,
--			    _("call may throw exception that does not "
--			      "propagate"), diag_musttail);
--    else
--      maybe_error_musttail (call, _("code between call and return"),
--			    diag_musttail);
--    return;
-+    if (stmt != last_stmt)
-+      {
-+	maybe_error_musttail (call, _("code between call and return"),
-+			      diag_musttail);
-+	return;
-+      }
-+
-+    edge e;
-+    edge_iterator ei;
-+    FOR_EACH_EDGE (e, ei, bb->succs)
-+      if (e->flags & EDGE_EH)
-+	break;
-+
-+    if (!e)
-+      {
-+	maybe_error_musttail (call,
-+			      _("call may throw exception that does not "
-+				"propagate"), diag_musttail);
-+	return;
-+      }
-+
-+    if (!gimple_call_must_tail_p (call)
-+	|| !empty_eh_cleanup (e->dest, 20)
-+	|| EDGE_COUNT (bb->succs) > 2)
-+      {
-+	maybe_error_musttail (call,
-+			      _("call may throw exception caught locally "
-+				"or perform cleanups"), diag_musttail);
-+	return;
-+      }
-   }
- 
-   /* If the function returns a value, then at present, the tail call
-@@ -844,8 +910,7 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
-   a = NULL_TREE;
-   auto_bitmap to_move_defs;
-   auto_vec<gimple *> to_move_stmts;
--  bool is_noreturn
--    = EDGE_COUNT (bb->succs) == 0 && gimple_call_noreturn_p (call);
-+  bool is_noreturn = gimple_call_noreturn_p (call);
- 
-   abb = bb;
-   agsi = gsi;
-@@ -857,8 +922,9 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
- 
-       while (gsi_end_p (agsi))
- 	{
--	  ass_var = propagate_through_phis (ass_var, single_succ_edge (abb));
--	  abb = single_succ (abb);
-+	  edge e = single_non_eh_succ_edge (abb);
-+	  ass_var = propagate_through_phis (ass_var, e);
-+	  abb = e->dest;
- 	  agsi = gsi_start_bb (abb);
- 	}
- 
-@@ -932,6 +998,11 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
-   /* See if this is a tail call we can handle.  */
-   if (is_noreturn)
-     {
-+      if (gimple_call_internal_p (call))
-+	{
-+	  maybe_error_musttail (call, _("internal call"), diag_musttail);
-+	  return;
-+	}
-       tree rettype = TREE_TYPE (TREE_TYPE (current_function_decl));
-       tree calltype = TREE_TYPE (gimple_call_fntype (call));
-       if (!VOID_TYPE_P (rettype)
-@@ -1193,11 +1264,6 @@ static void
- decrease_profile (basic_block bb, profile_count count)
- {
-   bb->count = bb->count - count;
--  if (!single_succ_p (bb))
--    {
--      gcc_assert (!EDGE_COUNT (bb->succs));
--      return;
--    }
- }
- 
- /* Eliminates tail call described by T.  TMP_VARS is a list of
-@@ -1262,7 +1328,7 @@ eliminate_tail_call (struct tailcall *t, class loop *&new_loop)
-   else
-     {
-       /* Number of executions of function has reduced by the tailcall.  */
--      e = single_succ_edge (gsi_bb (t->call_gsi));
-+      e = single_non_eh_succ_edge (gsi_bb (t->call_gsi));
- 
-       profile_count count = e->count ();
- 
-@@ -1277,8 +1343,7 @@ eliminate_tail_call (struct tailcall *t, class loop *&new_loop)
- 	decrease_profile (e->dest, count);
- 
-       /* Replace the call by a jump to the start of function.  */
--      e = redirect_edge_and_branch (single_succ_edge (gsi_bb (t->call_gsi)),
--				    first);
-+      e = redirect_edge_and_branch (e, first);
-     }
-   gcc_assert (e);
-   PENDING_STMT (e) = NULL;
-@@ -1443,7 +1508,9 @@ tree_optimize_tail_calls_1 (bool opt_tailcalls, bool only_musttail,
-     {
-       basic_block bb;
-       FOR_EACH_BB_FN (bb, cfun)
--	if (EDGE_COUNT (bb->succs) == 0)
-+	if (EDGE_COUNT (bb->succs) == 0
-+	    || (single_succ_p (bb)
-+		&& (single_succ_edge (bb)->flags & EDGE_EH)))
- 	  if (gimple *c = last_nondebug_stmt (bb))
- 	    if (is_gimple_call (c)
- 		&& gimple_call_must_tail_p (as_a <gcall *> (c))
-
-base-commit: aca8155c09001f269a20d6df438fa0e749dd5388
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 8223363..48fa9bd 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -2,7 +2,6 @@
 
 	- 80_all_PR119376-tailc-Don-t-fail-musttail-calls-if-they-use-or-could.patch
 	+ 82_all_PR119318-ipa-cp.patch
-	+ 83_all_PR119491-tailcall-eh.patch
 
 50	31 March 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-02 18:48 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-02 18:48 UTC (permalink / raw
  To: gentoo-commits
commit:     43e87541519c3e496094d7febd6b772ce0fb33b9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  2 18:45:07 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr  2 18:45:07 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=43e87541
15.0.0: cut patchset 51
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 48fa9bd..f01476e 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-51	????
+51	2 April 2025
 
 	- 80_all_PR119376-tailc-Don-t-fail-musttail-calls-if-they-use-or-could.patch
 	+ 82_all_PR119318-ipa-cp.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-04 19:06 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-04 19:06 UTC (permalink / raw
  To: gentoo-commits
commit:     f848da3b363c51d555e4b1a391afd3d6cf0a6fe3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Apr  4 19:06:02 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Apr  4 19:06:31 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=f848da3b
15.0.0: add combine patches
They should be committed shortly but I want to test all the musttail
patches now, so let's save me building twice.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...ow-2-2-combinations-but-with-a-tweak-PR11.patch | 204 ++++++++++++++++++
 ...id-split_i2i3-search-if-i2-is-unchanged-P.patch |  54 +++++
 ...Optimise-distribute_links-search-PR116398.patch |  99 +++++++++
 ...it-insn-searchs-for-2-2-combinations-PR11.patch | 240 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   7 +
 5 files changed, 604 insertions(+)
diff --git a/15.0.0/gentoo/83_all_combine-Allow-2-2-combinations-but-with-a-tweak-PR11.patch b/15.0.0/gentoo/83_all_combine-Allow-2-2-combinations-but-with-a-tweak-PR11.patch
new file mode 100644
index 0000000..fd85bcd
--- /dev/null
+++ b/15.0.0/gentoo/83_all_combine-Allow-2-2-combinations-but-with-a-tweak-PR11.patch
@@ -0,0 +1,204 @@
+https://inbox.sourceware.org/gcc-patches/mptecy8xowo.fsf@arm.com/
+
+From de2f5e9c4ce4bb674fb0da191102838a6bdd92f6 Mon Sep 17 00:00:00 2001
+Message-ID: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
+From: Richard Sandiford <richard.sandiford@arm.com>
+Date: Fri, 4 Apr 2025 10:21:43 +0100
+Subject: [PATCH 1/4] combine: Allow 2->2 combinations, but with a tweak
+ [PR116398]
+
+One of the problems in PR101523 was that, after each successful
+2->2 combination attempt, try_combine would restart combination
+attempts at i2 even if i2 hadn't changed.  This led to quadratic
+behaviour as the same failed combinations between i2 and i3 were
+tried repeatedly.
+
+The original patch for the PR dealt with that by disallowing 2->2
+combinations.  However, that led to various optimisation regressions,
+so there was interest in allowing the combinations again, at least
+until an alternative way of getting the same results is in place.
+
+This patch is a variant of Richi's in:
+
+  https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101523#c53
+
+but limited to when we're combining 2 instructions.
+
+This speeds up combine by 10x on the original PR101523 testcase
+and reduces combine's memory footprint by 100x.
+
+gcc/
+	PR testsuite/116398
+	* combine.cc (try_combine): Reallow 2->2 combinations.  Detect when
+	only i3 has changed and restart from i3 in that case.
+
+gcc/testsuite/
+	* gcc.target/aarch64/popcnt-le-1.c: Account for commutativity of TST.
+	* gcc.target/aarch64/popcnt-le-3.c: Likewise AND.
+	* gcc.target/aarch64/sve/pred-not-gen-1.c: Revert previous patch.
+	* gcc.target/aarch64/sve/pred-not-gen-4.c: Likewise.
+	* gcc.target/aarch64/sve/var_stride_2.c: Likewise.
+	* gcc.target/aarch64/sve/var_stride_4.c: Likewise.
+
+Co-authored-by: Richard Biener <rguenther@suse.de>
+---
+ gcc/combine.cc                                     | 14 ++++----------
+ gcc/testsuite/gcc.target/aarch64/popcnt-le-1.c     |  4 ++--
+ gcc/testsuite/gcc.target/aarch64/popcnt-le-3.c     |  4 ++--
+ gcc/testsuite/gcc.target/aarch64/pr100056.c        |  4 +++-
+ .../gcc.target/aarch64/sve/pred-not-gen-1.c        |  4 ++--
+ .../gcc.target/aarch64/sve/pred-not-gen-4.c        |  4 ++--
+ .../gcc.target/aarch64/sve/var_stride_2.c          |  3 ++-
+ .../gcc.target/aarch64/sve/var_stride_4.c          |  3 ++-
+ 8 files changed, 19 insertions(+), 21 deletions(-)
+
+diff --git a/gcc/combine.cc b/gcc/combine.cc
+index 1b6c4e314cc9..65a87a45b3be 100644
+--- a/gcc/combine.cc
++++ b/gcc/combine.cc
+@@ -4210,16 +4210,7 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
+       adjust_for_new_dest (i3);
+     }
+ 
+-  /* If I2 didn't change, this is not a combination (but a simplification or
+-     canonicalisation with context), which should not be done here.  Doing
+-     it here explodes the algorithm.  Don't.  */
+-  if (rtx_equal_p (newi2pat, PATTERN (i2)))
+-    {
+-      if (dump_file)
+-	fprintf (dump_file, "i2 didn't change, not doing this\n");
+-      undo_all ();
+-      return 0;
+-    }
++  bool only_i3_changed = !i0 && !i1 && rtx_equal_p (newi2pat, PATTERN (i2));
+ 
+   /* We now know that we can do this combination.  Merge the insns and
+      update the status of registers and LOG_LINKS.  */
+@@ -4787,6 +4778,9 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
+   combine_successes++;
+   undo_commit ();
+ 
++  if (only_i3_changed)
++    return i3;
++
+   rtx_insn *ret = newi2pat ? i2 : i3;
+   if (added_links_insn && DF_INSN_LUID (added_links_insn) < DF_INSN_LUID (ret))
+     ret = added_links_insn;
+diff --git a/gcc/testsuite/gcc.target/aarch64/popcnt-le-1.c b/gcc/testsuite/gcc.target/aarch64/popcnt-le-1.c
+index b4141da982c9..843fdac9fd8e 100644
+--- a/gcc/testsuite/gcc.target/aarch64/popcnt-le-1.c
++++ b/gcc/testsuite/gcc.target/aarch64/popcnt-le-1.c
+@@ -8,7 +8,7 @@
+ /*
+ ** le32:
+ **	sub	w([0-9]+), w0, #1
+-**	tst	w0, w\1
++**	tst	(?:w0, w\1|w\1, w0)
+ **	cset	w0, eq
+ **	ret
+ */
+@@ -20,7 +20,7 @@ unsigned le32 (const unsigned int a) {
+ /*
+ ** gt32:
+ **	sub	w([0-9]+), w0, #1
+-**	tst	w0, w\1
++**	tst	(?:w0, w\1|w\1, w0)
+ **	cset	w0, ne
+ **	ret
+ */
+diff --git a/gcc/testsuite/gcc.target/aarch64/popcnt-le-3.c b/gcc/testsuite/gcc.target/aarch64/popcnt-le-3.c
+index b811e6f6e8fe..3b558e95d819 100644
+--- a/gcc/testsuite/gcc.target/aarch64/popcnt-le-3.c
++++ b/gcc/testsuite/gcc.target/aarch64/popcnt-le-3.c
+@@ -8,7 +8,7 @@
+ /*
+ ** le16:
+ **	sub	w([0-9]+), w0, #1
+-**	and	w([0-9]+), w0, w\1
++**	and	w([0-9]+), (?:w0, w\1|w\1, w0)
+ **	tst	w\2, 65535
+ **	cset	w0, eq
+ **	ret
+@@ -21,7 +21,7 @@ unsigned le16 (const unsigned short a) {
+ /*
+ ** gt16:
+ **	sub	w([0-9]+), w0, #1
+-**	and	w([0-9]+), w0, w\1
++**	and	w([0-9]+), (?:w0, w\1|w\1, w0)
+ **	tst	w\2, 65535
+ **	cset	w0, ne
+ **	ret
+diff --git a/gcc/testsuite/gcc.target/aarch64/pr100056.c b/gcc/testsuite/gcc.target/aarch64/pr100056.c
+index 0b77824da457..70499772d285 100644
+--- a/gcc/testsuite/gcc.target/aarch64/pr100056.c
++++ b/gcc/testsuite/gcc.target/aarch64/pr100056.c
+@@ -1,7 +1,9 @@
+ /* PR target/100056 */
+ /* { dg-do compile } */
+ /* { dg-options "-O2" } */
+-/* { dg-final { scan-assembler-not {\t[us]bfiz\tw[0-9]+, w[0-9]+, 11} } } */
++/* { dg-final { scan-assembler-not {\t[us]bfiz\tw[0-9]+, w[0-9]+, 11} { xfail *-*-* } } } */
++/* { dg-final { scan-assembler-times {\t[us]bfiz\tw[0-9]+, w[0-9]+, 11} 2 } } */
++/* { dg-final { scan-assembler-times {\tadd\tw[0-9]+, w[0-9]+, w[0-9]+, uxtb\n} 2 } } */
+ 
+ int
+ or_shift_u8 (unsigned char i)
+diff --git a/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-1.c b/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-1.c
+index a7d2795ebe23..c9a8b82c48ac 100644
+--- a/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-1.c
++++ b/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-1.c
+@@ -19,6 +19,6 @@ void f10(double * restrict z, double * restrict w, double * restrict x, double *
+     }
+ }
+ 
+-/* { dg-final { scan-assembler-not {\tbic\t} { xfail *-*-* } } } */
+-/* { dg-final { scan-assembler-times {\tnot\tp[0-9]+\.b, p[0-9]+/z, p[0-9]+\.b\n} 1 { xfail *-*-* } } } */
++/* { dg-final { scan-assembler-not {\tbic\t} } } */
++/* { dg-final { scan-assembler-times {\tnot\tp[0-9]+\.b, p[0-9]+/z, p[0-9]+\.b\n} 1 } } */
+ /* { dg-final { scan-assembler-times {\tfcmgt\tp[0-9]+\.d, p[0-9]+/z, z[0-9]+\.d, #0} 1 } } */
+diff --git a/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-4.c b/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-4.c
+index 20cbd7550b7e..1845bd3f0f70 100644
+--- a/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-4.c
++++ b/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-4.c
+@@ -8,6 +8,6 @@ void f13(double * restrict z, double * restrict w, double * restrict x, double *
+     }
+ }
+ 
+-/* { dg-final { scan-assembler-not {\tbic\t} { xfail *-*-* } } } */
+-/* { dg-final { scan-assembler-times {\tnot\tp[0-9]+\.b, p[0-9]+/z, p[0-9]+\.b\n} 1 { xfail *-*-* } } } */
++/* { dg-final { scan-assembler-not {\tbic\t} } } */
++/* { dg-final { scan-assembler-times {\tnot\tp[0-9]+\.b, p[0-9]+/z, p[0-9]+\.b\n} 1 } } */
+ /* { dg-final { scan-assembler-times {\tfcmuo\tp[0-9]+\.d, p[0-9]+/z, z[0-9]+\.d, z[0-9]+\.d} 1 } } */
+diff --git a/gcc/testsuite/gcc.target/aarch64/sve/var_stride_2.c b/gcc/testsuite/gcc.target/aarch64/sve/var_stride_2.c
+index 33b9f0f197e4..b8afea70207f 100644
+--- a/gcc/testsuite/gcc.target/aarch64/sve/var_stride_2.c
++++ b/gcc/testsuite/gcc.target/aarch64/sve/var_stride_2.c
+@@ -16,7 +16,8 @@ f (TYPE *x, TYPE *y, unsigned short n, unsigned short m)
+ /* { dg-final { scan-assembler {\tldr\tw[0-9]+} } } */
+ /* { dg-final { scan-assembler {\tstr\tw[0-9]+} } } */
+ /* Should multiply by (257-1)*4 rather than (VF-1)*4 or (VF-2)*4.  */
+-/* { dg-final { scan-assembler-times {\tadd\tx[0-9]+, x[0-9]+, x[0-9]+, lsl 10\n} 2 } } */
++/* { dg-final { scan-assembler-times {\tubfiz\tx[0-9]+, x2, 10, 16\n} 1 } } */
++/* { dg-final { scan-assembler-times {\tubfiz\tx[0-9]+, x3, 10, 16\n} 1 } } */
+ /* { dg-final { scan-assembler-not {\tcmp\tx[0-9]+, 0} } } */
+ /* { dg-final { scan-assembler-not {\tcmp\tw[0-9]+, 0} } } */
+ /* { dg-final { scan-assembler-not {\tcsel\tx[0-9]+} } } */
+diff --git a/gcc/testsuite/gcc.target/aarch64/sve/var_stride_4.c b/gcc/testsuite/gcc.target/aarch64/sve/var_stride_4.c
+index 71b826a4c1bb..d2e74f9d4175 100644
+--- a/gcc/testsuite/gcc.target/aarch64/sve/var_stride_4.c
++++ b/gcc/testsuite/gcc.target/aarch64/sve/var_stride_4.c
+@@ -16,7 +16,8 @@ f (TYPE *x, TYPE *y, int n, int m)
+ /* { dg-final { scan-assembler {\tldr\tw[0-9]+} } } */
+ /* { dg-final { scan-assembler {\tstr\tw[0-9]+} } } */
+ /* Should multiply by (257-1)*4 rather than (VF-1)*4.  */
+-/* { dg-final { scan-assembler-times {\t(?:lsl\tx[0-9]+, x[0-9]+, 10|sbfiz\tx[0-9]+, x[0-9]+, 10, 32)\n} 2 } } */
++/* { dg-final { scan-assembler-times {\tsbfiz\tx[0-9]+, x2, 10, 32\n} 1 } } */
++/* { dg-final { scan-assembler-times {\tsbfiz\tx[0-9]+, x3, 10, 32\n} 1 } } */
+ /* { dg-final { scan-assembler {\tcmp\tw2, 0} } } */
+ /* { dg-final { scan-assembler {\tcmp\tw3, 0} } } */
+ /* { dg-final { scan-assembler-times {\tcsel\tx[0-9]+} 4 } } */
+
+base-commit: d25728c98682c058bfda79333c94b0a8cf2a3f49
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/84_all_combine-Avoid-split_i2i3-search-if-i2-is-unchanged-P.patch b/15.0.0/gentoo/84_all_combine-Avoid-split_i2i3-search-if-i2-is-unchanged-P.patch
new file mode 100644
index 0000000..19d4917
--- /dev/null
+++ b/15.0.0/gentoo/84_all_combine-Avoid-split_i2i3-search-if-i2-is-unchanged-P.patch
@@ -0,0 +1,54 @@
+https://inbox.sourceware.org/gcc-patches/mptecy8xowo.fsf@arm.com/
+
+From fac8faddc3fca52b6d51c0d1a57323012a1fe4e9 Mon Sep 17 00:00:00 2001
+Message-ID: <fac8faddc3fca52b6d51c0d1a57323012a1fe4e9.1743793443.git.sam@gentoo.org>
+In-Reply-To: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
+References: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
+From: Richard Sandiford <richard.sandiford@arm.com>
+Date: Fri, 4 Apr 2025 10:22:12 +0100
+Subject: [PATCH 2/4] combine: Avoid split_i2i3 search if i2 is unchanged
+ [PR116398]
+
+When combining a single-set i2 into a multi-set i3, combine
+first tries to match the new multi-set in-place.  If that fails,
+combine considers splitting the multi-set so that one set goes in
+i2 and the other set stays in i3.  That moves a destination from i3
+to i2 and so combine needs to update any associated log link for that
+destination to point to i2 rather than i3.
+
+However, that kind of split can also occur for 2->2 combinations.
+For a 2-instruction combination in which i2 doesn't die in i3, combine
+tries a 2->1 combination by turning i3 into a parallel of the original
+i2 and the combined i3.  If that fails, combine will split the parallel
+as above, so that the first set goes in i2 and the second set goes in i3.
+But that can often leave i2 unchanged, meaning that no destinations have
+moved and so no search is necessary.
+
+gcc/
+	PR testsuite/116398
+	* combine.cc (try_combine): Shortcut the split_i2i3 handling if
+	i2 is unchanged.
+---
+ gcc/combine.cc | 6 ++++++
+ 1 file changed, 6 insertions(+)
+
+diff --git a/gcc/combine.cc b/gcc/combine.cc
+index 65a87a45b3be..e29cff7147d9 100644
+--- a/gcc/combine.cc
++++ b/gcc/combine.cc
+@@ -4212,6 +4212,12 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
+ 
+   bool only_i3_changed = !i0 && !i1 && rtx_equal_p (newi2pat, PATTERN (i2));
+ 
++  /* If only i3 has changed, any split of the combined instruction just
++     restored i2 to its original state.  No destinations moved from i3
++     to i2.  */
++  if (only_i3_changed)
++    split_i2i3 = false;
++
+   /* We now know that we can do this combination.  Merge the insns and
+      update the status of registers and LOG_LINKS.  */
+ 
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/85_all_combine-Optimise-distribute_links-search-PR116398.patch b/15.0.0/gentoo/85_all_combine-Optimise-distribute_links-search-PR116398.patch
new file mode 100644
index 0000000..f8849ba
--- /dev/null
+++ b/15.0.0/gentoo/85_all_combine-Optimise-distribute_links-search-PR116398.patch
@@ -0,0 +1,99 @@
+https://inbox.sourceware.org/gcc-patches/mptecy8xowo.fsf@arm.com/
+
+From bc27a2f371602bf897ff4da1620a56eeeeebf8ff Mon Sep 17 00:00:00 2001
+Message-ID: <bc27a2f371602bf897ff4da1620a56eeeeebf8ff.1743793443.git.sam@gentoo.org>
+In-Reply-To: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
+References: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
+From: Richard Sandiford <richard.sandiford@arm.com>
+Date: Fri, 4 Apr 2025 10:22:32 +0100
+Subject: [PATCH 3/4] combine: Optimise distribute_links search [PR116398]
+
+Another problem in PR101523 was that, after each successful 2->2
+combination attempt, distribute_links would search further and further
+for the next combinable use of the i2 destination.  Each search would
+start at i2 itself, making the search quadratic in the worst case.
+
+In a 2->2 combination, if i2 is unchanged, the search can start at i3
+instead of i2.  The same thing applies to i2 when distributing i2's
+links, since the only changes to earlier instructions are the deletion
+of i0 and i1.
+
+This change, combined with the previous split_i2i3 patch, gives a
+34.6% speedup in combine for the testcase in PR101523.  Combine
+goes from being 41% to 34% of compile time.
+
+gcc/
+	PR testsuite/116398
+	* combine.cc (distribute_links): Take an optional start point.
+	(try_combine): If only i3 has changed, only distribute i3's links,
+	not i2's.  Start the search for the new use from i3 rather than
+	from the definition instruction.  Likewise start the search for
+	the new use from i2 when distributing i2's links.
+---
+ gcc/combine.cc | 27 +++++++++++++++++++--------
+ 1 file changed, 19 insertions(+), 8 deletions(-)
+
+diff --git a/gcc/combine.cc b/gcc/combine.cc
+index e29cff7147d9..e99b064c98d4 100644
+--- a/gcc/combine.cc
++++ b/gcc/combine.cc
+@@ -472,7 +472,7 @@ static void move_deaths (rtx, rtx, int, rtx_insn *, rtx *);
+ static bool reg_bitfield_target_p (rtx, rtx);
+ static void distribute_notes (rtx, rtx_insn *, rtx_insn *, rtx_insn *,
+ 			      rtx, rtx, rtx);
+-static void distribute_links (struct insn_link *);
++static void distribute_links (struct insn_link *, rtx_insn * = nullptr);
+ static void mark_used_regs_combine (rtx);
+ static void record_promoted_value (rtx_insn *, rtx);
+ static bool unmentioned_reg_p (rtx, rtx);
+@@ -4592,10 +4592,15 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
+ 			    NULL_RTX, NULL_RTX, NULL_RTX);
+       }
+ 
+-    distribute_links (i3links);
+-    distribute_links (i2links);
+-    distribute_links (i1links);
+-    distribute_links (i0links);
++    if (only_i3_changed)
++      distribute_links (i3links, i3);
++    else
++      {
++	distribute_links (i3links);
++	distribute_links (i2links, i2);
++	distribute_links (i1links);
++	distribute_links (i0links);
++      }
+ 
+     if (REG_P (i2dest))
+       {
+@@ -14986,10 +14991,13 @@ distribute_notes (rtx notes, rtx_insn *from_insn, rtx_insn *i3, rtx_insn *i2,
+ \f
+ /* Similarly to above, distribute the LOG_LINKS that used to be present on
+    I3, I2, and I1 to new locations.  This is also called to add a link
+-   pointing at I3 when I3's destination is changed.  */
++   pointing at I3 when I3's destination is changed.
++
++   If START is nonnull and an insn, we know that the next location for each
++   link is no earlier than START.  */
+ 
+ static void
+-distribute_links (struct insn_link *links)
++distribute_links (struct insn_link *links, rtx_insn *start)
+ {
+   struct insn_link *link, *next_link;
+ 
+@@ -15055,7 +15063,10 @@ distribute_links (struct insn_link *links)
+ 	 I3 to I2.  Also note that not much searching is typically done here
+ 	 since most links don't point very far away.  */
+ 
+-      for (insn = NEXT_INSN (link->insn);
++      insn = start;
++      if (!insn || NOTE_P (insn))
++	insn = NEXT_INSN (link->insn);
++      for (;
+ 	   (insn && (this_basic_block->next_bb == EXIT_BLOCK_PTR_FOR_FN (cfun)
+ 		     || BB_HEAD (this_basic_block->next_bb) != insn));
+ 	   insn = NEXT_INSN (insn))
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch b/15.0.0/gentoo/86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch
new file mode 100644
index 0000000..b185cba
--- /dev/null
+++ b/15.0.0/gentoo/86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch
@@ -0,0 +1,240 @@
+https://inbox.sourceware.org/gcc-patches/mptecy8xowo.fsf@arm.com/
+
+From 247ac81832821bade9fa36c350d220dca039d383 Mon Sep 17 00:00:00 2001
+Message-ID: <247ac81832821bade9fa36c350d220dca039d383.1743793443.git.sam@gentoo.org>
+In-Reply-To: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
+References: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
+From: Richard Sandiford <richard.sandiford@arm.com>
+Date: Fri, 4 Apr 2025 10:23:00 +0100
+Subject: [PATCH 4/4] combine: Limit insn searchs for 2->2 combinations
+ [PR116398]
+
+As noted in the previous patch, combine still takes >30% of
+compile time in the original testcase for PR101523.  The problem
+is that try_combine uses linear insn searches for some dataflow
+queries, so in the worst case, an unlimited number of 2->2
+combinations for the same i2 can lead to quadratic behaviour.
+
+This patch limits distribute_links to a certain number
+of instructions when i2 is unchanged.  As Segher said in the PR trail,
+it would make more conceptual sense to apply the limit unconditionally,
+but I thought it would be better to change as little as possible at
+this development stage.  Logically, in stage 1, the --param should
+be applied directly by distribute_links with no input from callers.
+
+As I mentioned in:
+
+  https://gcc.gnu.org/bugzilla/show_bug.cgi?id=116398#c28
+
+I think it's safe to drop log links even if a use exists.  All
+processing of log links seems to handle the absence of a link
+for a particular register in a conservative way.
+
+The initial set-up errs on the side of dropping links, since for example
+create_log_links has:
+
+             /* flow.c claimed:
+
+                 We don't build a LOG_LINK for hard registers contained
+                 in ASM_OPERANDs.  If these registers get replaced,
+                 we might wind up changing the semantics of the insn,
+                 even if reload can make what appear to be valid
+                 assignments later.  */
+              if (regno < FIRST_PSEUDO_REGISTER
+                  && asm_noperands (PATTERN (use_insn)) >= 0)
+                continue;
+
+which excludes combinations by dropping log links, rather than during
+try_combine.  And:
+
+      /* If this register is being initialized using itself, and the
+         register is uninitialized in this basic block, and there are
+         no LOG_LINKS which set the register, then part of the
+         register is uninitialized.  In that case we can't assume
+         anything about the number of nonzero bits.
+
+         ??? We could do better if we checked this in
+         reg_{nonzero_bits,num_sign_bit_copies}_for_combine.  Then we
+         could avoid making assumptions about the insn which initially
+         sets the register, while still using the information in other
+         insns.  We would have to be careful to check every insn
+         involved in the combination.  */
+
+      if (insn
+          && reg_referenced_p (x, PATTERN (insn))
+          && !REGNO_REG_SET_P (DF_LR_IN (BLOCK_FOR_INSN (insn)),
+                               REGNO (x)))
+        {
+          struct insn_link *link;
+
+          FOR_EACH_LOG_LINK (link, insn)
+            if (dead_or_set_p (link->insn, x))
+              break;
+          if (!link)
+            {
+              rsp->nonzero_bits = GET_MODE_MASK (mode);
+              rsp->sign_bit_copies = 1;
+              return;
+            }
+        }
+
+treats the lack of a log link as a possible sign of uninitialised data,
+but that would be a missed optimisation rather than a correctness issue.
+
+One question is what the default --param value should be.  I went with
+Jakub's suggestion of 3000 from:
+
+  https://gcc.gnu.org/bugzilla/show_bug.cgi?id=116398#c25
+
+Also, to answer Jakub's question in that comment, I tried bisecting:
+
+  int limit = atoi (getenv ("BISECT"));
+
+(so applying the limit for all calls from try_combine) with an
+abort in distribute_links if the limit caused a link to be skipped.
+The minimum BISECT value that allowed an aarch64-linux-gnu bootstrap
+to succeed with --enable-languages=all --enable-checking=yes,rtl,extra
+was 142, so much lower than the parameter value.  I realised too late
+that --enable-checking=release would probably have been a more
+interesting test.
+
+The previous patch meant that distribute_links itself is now linear
+for a given i2 definition, since each search starts at the previous
+last use, rather than at i2 itself.  This means that the limit has
+to be applied cumulatively across all searches for the same link.
+
+The patch does that by storing a counter in the insn_link structure.
+There was a 32-bit hole there on LP64 hosts.
+
+gcc/
+	PR testsuite/116398
+	* params.opt (-param=max-combine-search-insns=): New param.
+	* doc/invoke.texi: Document it.
+	* combine.cc (insn_link::insn_count): New field.
+	(alloc_insn_link): Initialize it.
+	(distribute_links): Add a limit parameter.
+	(try_combine): Use the new param to limit distribute_links
+	when only i3 has changed.
+---
+ gcc/combine.cc      | 21 +++++++++++++++++----
+ gcc/doc/invoke.texi |  9 +++++++++
+ gcc/params.opt      |  4 ++++
+ 3 files changed, 30 insertions(+), 4 deletions(-)
+
+diff --git a/gcc/combine.cc b/gcc/combine.cc
+index e99b064c98d4..5f085187cfef 100644
+--- a/gcc/combine.cc
++++ b/gcc/combine.cc
+@@ -309,6 +309,7 @@ static int *uid_insn_cost;
+ struct insn_link {
+   rtx_insn *insn;
+   unsigned int regno;
++  int insn_count;
+   struct insn_link *next;
+ };
+ 
+@@ -342,6 +343,7 @@ alloc_insn_link (rtx_insn *insn, unsigned int regno, struct insn_link *next)
+ 					  sizeof (struct insn_link));
+   l->insn = insn;
+   l->regno = regno;
++  l->insn_count = 0;
+   l->next = next;
+   return l;
+ }
+@@ -472,7 +474,8 @@ static void move_deaths (rtx, rtx, int, rtx_insn *, rtx *);
+ static bool reg_bitfield_target_p (rtx, rtx);
+ static void distribute_notes (rtx, rtx_insn *, rtx_insn *, rtx_insn *,
+ 			      rtx, rtx, rtx);
+-static void distribute_links (struct insn_link *, rtx_insn * = nullptr);
++static void distribute_links (struct insn_link *, rtx_insn * = nullptr,
++			      int limit = INT_MAX);
+ static void mark_used_regs_combine (rtx);
+ static void record_promoted_value (rtx_insn *, rtx);
+ static bool unmentioned_reg_p (rtx, rtx);
+@@ -4593,7 +4596,7 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
+       }
+ 
+     if (only_i3_changed)
+-      distribute_links (i3links, i3);
++      distribute_links (i3links, i3, param_max_combine_search_insns);
+     else
+       {
+ 	distribute_links (i3links);
+@@ -14994,10 +14997,12 @@ distribute_notes (rtx notes, rtx_insn *from_insn, rtx_insn *i3, rtx_insn *i2,
+    pointing at I3 when I3's destination is changed.
+ 
+    If START is nonnull and an insn, we know that the next location for each
+-   link is no earlier than START.  */
++   link is no earlier than START.  LIMIT is the maximum number of nondebug
++   instructions that can be scanned when looking for the next use of a
++   definition.  */
+ 
+ static void
+-distribute_links (struct insn_link *links, rtx_insn *start)
++distribute_links (struct insn_link *links, rtx_insn *start, int limit)
+ {
+   struct insn_link *link, *next_link;
+ 
+@@ -15063,9 +15068,12 @@ distribute_links (struct insn_link *links, rtx_insn *start)
+ 	 I3 to I2.  Also note that not much searching is typically done here
+ 	 since most links don't point very far away.  */
+ 
++      int count = 0;
+       insn = start;
+       if (!insn || NOTE_P (insn))
+ 	insn = NEXT_INSN (link->insn);
++      else
++	count = link->insn_count;
+       for (;
+ 	   (insn && (this_basic_block->next_bb == EXIT_BLOCK_PTR_FOR_FN (cfun)
+ 		     || BB_HEAD (this_basic_block->next_bb) != insn));
+@@ -15086,6 +15094,11 @@ distribute_links (struct insn_link *links, rtx_insn *start)
+ 	  }
+ 	else if (INSN_P (insn) && reg_set_p (reg, insn))
+ 	  break;
++	else if (count >= limit)
++	  break;
++	else
++	  count += 1;
++      link->insn_count = count;
+ 
+       /* If we found a place to put the link, place it there unless there
+ 	 is already a link to the same insn as LINK at that point.  */
+diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
+index 4c9af429ab08..0903cd2b7f23 100644
+--- a/gcc/doc/invoke.texi
++++ b/gcc/doc/invoke.texi
+@@ -16518,6 +16518,15 @@ in combiner for a pseudo register as last known value of that register.
+ @item max-combine-insns
+ The maximum number of instructions the RTL combiner tries to combine.
+ 
++@item max-combine-search-insns
++The maximum number of instructions that the RTL combiner searches in order
++to find the next use of a given register definition.  If this limit is reached
++without finding such a use, the combiner will stop trying to optimize the
++definition.
++
++Currently this limit only applies after certain successful combination
++attempts, but it could be extended to other cases in future.
++
+ @item integer-share-limit
+ Small integer constants can use a shared data structure, reducing the
+ compiler's memory usage and increasing its speed.  This sets the maximum
+diff --git a/gcc/params.opt b/gcc/params.opt
+index 4f4eb4d7a2a5..422d082b3557 100644
+--- a/gcc/params.opt
++++ b/gcc/params.opt
+@@ -477,6 +477,10 @@ The maximum number of instructions to consider to unroll in a loop on average.
+ Common Joined UInteger Var(param_max_combine_insns) Init(4) IntegerRange(2, 4) Param Optimization
+ The maximum number of insns combine tries to combine.
+ 
++-param=max-combine-search-insns=
++Common Joined UInteger Var(param_max_combine_search_insns) Init(3000) Param Optimization
++The maximum number of instructions that combine searches in order to find the next use of a particular register.
++
+ -param=max-completely-peel-loop-nest-depth=
+ Common Joined UInteger Var(param_max_unroll_iterations) Init(8) Param Optimization
+ The maximum depth of a loop nest we completely peel.
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index f01476e..5e4d154 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,10 @@
+52	????
+
+	+ 83_all_combine-Allow-2-2-combinations-but-with-a-tweak-PR11.patch
+	+ 84_all_combine-Avoid-split_i2i3-search-if-i2-is-unchanged-P.patch
+	+ 85_all_combine-Optimise-distribute_links-search-PR116398.patch
+	+ 86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch
+
 51	2 April 2025
 
 	- 80_all_PR119376-tailc-Don-t-fail-musttail-calls-if-they-use-or-could.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-05  1:43 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-05  1:43 UTC (permalink / raw
  To: gentoo-commits
commit:     84fc77fd1f6f9409c114e1c8756b3efadbfbb229
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Apr  5 01:42:24 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Apr  5 01:43:05 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=84fc77fd
15.0.0: add patch on top of combine fixes
Add 87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch which
fixes gcc.dg/rtl/x86_64/vector_eq.c regressing with the combine fixes.
I didn't notice as it's not part of the series.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...implify-rtx-Fix-shortcut-for-vector-eq-ne.patch | 131 +++++++++++++++++++++
 15.0.0/gentoo/README.history                       |   1 +
 2 files changed, 132 insertions(+)
diff --git a/15.0.0/gentoo/87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch b/15.0.0/gentoo/87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch
new file mode 100644
index 0000000..76c3552
--- /dev/null
+++ b/15.0.0/gentoo/87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch
@@ -0,0 +1,131 @@
+https://inbox.sourceware.org/gcc-patches/mpt7c443wm7.fsf@arm.com/
+
+From 5cc0c07a938202390b612f4e47934c09a17cad9a Mon Sep 17 00:00:00 2001
+Message-ID: <5cc0c07a938202390b612f4e47934c09a17cad9a.1743817315.git.sam@gentoo.org>
+From: Richard Sandiford <richard.sandiford@arm.com>
+Date: Tue, 1 Apr 2025 13:16:32 +0100
+Subject: [PATCH] simplify-rtx: Fix shortcut for vector eq/ne
+
+This patch forestalls a regression in gcc.dg/rtl/x86_64/vector_eq.c
+with the patch for PR116398.  The test wants:
+
+      (cinsn 3 (set (reg:V4SI <0>) (const_vector:V4SI [(const_int 0) (const_int 0) (const_int 0) (const_int 0)])))
+      (cinsn 5 (set (reg:V4SI <2>)
+		    (eq:V4SI (reg:V4SI <0>) (reg:V4SI <1>))))
+
+to be folded to a vector of -1s.  One unusual thing about the fold
+is that the <1> in the second insn is uninitialised; it looks like
+it should be replaced by <0>, or that there should be an insn 4 that
+copies <0> to <1>.
+
+As it stands, the test relies on init-regs to insert a zero
+initialisation of <1>.  This happens after all the cse/pre/fwprop
+stuff, with only dce passes between init-regs and combine.
+Combine therefore sees:
+
+(insn 3 2 8 2 (set (reg:V4SI 98)
+        (const_vector:V4SI [
+                (const_int 0 [0]) repeated x4
+            ])) 2403 {movv4si_internal}
+     (nil))
+(insn 8 3 9 2 (clobber (reg:V4SI 99)) -1
+     (nil))
+(insn 9 8 5 2 (set (reg:V4SI 99)
+        (const_vector:V4SI [
+                (const_int 0 [0]) repeated x4
+            ])) -1
+     (nil))
+(insn 5 9 7 2 (set (reg:V4SI 100)
+        (eq:V4SI (reg:V4SI 98)
+            (reg:V4SI 99))) 7874 {*sse2_eqv4si3}
+     (expr_list:REG_DEAD (reg:V4SI 99)
+        (expr_list:REG_DEAD (reg:V4SI 98)
+            (expr_list:REG_EQUAL (eq:V4SI (const_vector:V4SI [
+                            (const_int 0 [0]) repeated x4
+                        ])
+                    (reg:V4SI 99))
+                (nil)))))
+
+It looks like the test should then pass through a 3, 9 -> 5 combination,
+so that we get an (eq ...) between two zeros and fold it to a vector
+of -1s.  But although the combination is attempted, the fold doesn't
+happen.  Instead, combine is left to match the unsimplified (eq ...)
+between two zeros, which rightly fails.  The test only passes because
+late_combine2 happens to try simplifying an (eq ...) between reg X and
+reg X, which does fold to a vector of -1s.
+
+The different handling of registers and constants is due to this
+code in simplify_const_relational_operation:
+
+  if (INTEGRAL_MODE_P (mode) && trueop1 != const0_rtx
+      && (code == EQ || code == NE)
+      && ! ((REG_P (op0) || CONST_INT_P (trueop0))
+	    && (REG_P (op1) || CONST_INT_P (trueop1)))
+      && (tem = simplify_binary_operation (MINUS, mode, op0, op1)) != 0
+      /* We cannot do this if tem is a nonzero address.  */
+      && ! nonzero_address_p (tem))
+    return simplify_const_relational_operation (signed_condition (code),
+						mode, tem, const0_rtx);
+
+INTEGRAL_MODE_P matches vector integer modes, but everything else
+about the condition is written for scalar integers only.  Thus if
+trueop0 and trueop1 are equal vector constants, we'll bypass all
+the exclusions and try simplifying a subtraction.  This will succeed,
+giving a vector of zeros.  The recursive call will then try to simplify
+a comparison between the vector of zeros and const0_rtx, which isn't
+well-formed.  Luckily or unluckily, the ill-formedness doesn't trigger
+an ICE, but it does prevent any simplification from happening.
+
+The least-effort fix would be to replace INTEGRAL_MODE_P with
+SCALAR_INT_MODE_P.  But the fold does make conceptual sense for
+vectors too, so it seemed better to keep the INTEGRAL_MODE_P and
+generalise the rest of the condition to match.
+
+Tested on aarch64-linux-gnu & x86_64-linux-gnu.  OK to install?
+
+I'm hoping to post the actual patch for PR116398 later today.
+
+Richard
+
+gcc/
+	* simplify-rtx.cc (simplify_const_relational_operation): Generalize
+	the constant checks in the fold-via-minus path to match the
+	INTEGRAL_MODE_P condition.
+---
+ gcc/simplify-rtx.cc | 13 +++++++++----
+ 1 file changed, 9 insertions(+), 4 deletions(-)
+
+diff --git a/gcc/simplify-rtx.cc b/gcc/simplify-rtx.cc
+index fe007bc7d96a..6f969effdf99 100644
+--- a/gcc/simplify-rtx.cc
++++ b/gcc/simplify-rtx.cc
+@@ -6657,15 +6657,20 @@ simplify_const_relational_operation (enum rtx_code code,
+      we do not know the signedness of the operation on either the left or
+      the right hand side of the comparison.  */
+ 
+-  if (INTEGRAL_MODE_P (mode) && trueop1 != const0_rtx
++  if (INTEGRAL_MODE_P (mode)
++      && trueop1 != CONST0_RTX (mode)
+       && (code == EQ || code == NE)
+-      && ! ((REG_P (op0) || CONST_INT_P (trueop0))
+-	    && (REG_P (op1) || CONST_INT_P (trueop1)))
++      && ! ((REG_P (op0)
++	     || CONST_SCALAR_INT_P (trueop0)
++	     || CONST_VECTOR_P (trueop0))
++	    && (REG_P (op1)
++		|| CONST_SCALAR_INT_P (trueop1)
++		|| CONST_VECTOR_P (trueop1)))
+       && (tem = simplify_binary_operation (MINUS, mode, op0, op1)) != 0
+       /* We cannot do this if tem is a nonzero address.  */
+       && ! nonzero_address_p (tem))
+     return simplify_const_relational_operation (signed_condition (code),
+-						mode, tem, const0_rtx);
++						mode, tem, CONST0_RTX (mode));
+ 
+   if (! HONOR_NANS (mode) && code == ORDERED)
+     return const_true_rtx;
+
+base-commit: 2f62e66e1444d858e937faa7147f6cd06296b33b
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 5e4d154..632a6ea 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -4,6 +4,7 @@
 	+ 84_all_combine-Avoid-split_i2i3-search-if-i2-is-unchanged-P.patch
 	+ 85_all_combine-Optimise-distribute_links-search-PR116398.patch
 	+ 86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch
+	+ 87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch
 
 51	2 April 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-05  8:02 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-05  8:02 UTC (permalink / raw
  To: gentoo-commits
commit:     39fbf68843b5c9983fbc8d8eedbda8a0ee3f0091
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Apr  5 08:02:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Apr  5 08:02:08 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=39fbf688
15.0.0: cut patchset 52
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 632a6ea..4aed196 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-52	????
+52	4 Aprli 2025
 
 	+ 83_all_combine-Allow-2-2-combinations-but-with-a-tweak-PR11.patch
 	+ 84_all_combine-Avoid-split_i2i3-search-if-i2-is-unchanged-P.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-05 15:33 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-05 15:33 UTC (permalink / raw
  To: gentoo-commits
commit:     25603f8e2ac7815ea0d33bb3bb67add54eec017a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Apr  5 15:33:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Apr  5 15:33:23 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=25603f8e
15.0.0: add another tailcall patch
Bug: https://gcc.gnu.org/PR119614
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/88_all_PR119614.patch | 134 ++++++++++++++++++++++++++++++++++++
 1 file changed, 134 insertions(+)
diff --git a/15.0.0/gentoo/88_all_PR119614.patch b/15.0.0/gentoo/88_all_PR119614.patch
new file mode 100644
index 0000000..e577f8f
--- /dev/null
+++ b/15.0.0/gentoo/88_all_PR119614.patch
@@ -0,0 +1,134 @@
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c12
+
+2025-04-05  Jakub Jelinek  <jakub@redhat.com>
+
+	PR tree-optimization/119614
+	* tree-tailcall.cc (find_tail_calls): Remember edges which have been
+	walked through if !ass_var.  Perform IPA-VRP workaround even when
+	ret_var is not TREE_CONSTANT, in that case check in a loop if it is
+	a PHI result and in that case look at the PHI argument from
+	corresponding edge in the edge vector.
+
+	* g++.dg/opt/pr119613.C: Change { c || c++11 } in obviously C++ only
+	test to just c++11.
+	* g++.dg/opt/pr119614.C: New test.
+
+--- a/gcc/tree-tailcall.cc	2025-04-04 20:52:34.450015821 +0200
++++ b/gcc/tree-tailcall.cc	2025-04-05 14:50:50.106693562 +0200
+@@ -920,6 +920,7 @@ find_tail_calls (basic_block bb, struct
+   auto_bitmap to_move_defs;
+   auto_vec<gimple *> to_move_stmts;
+   bool is_noreturn = gimple_call_noreturn_p (call);
++  auto_vec<edge> edges;
+ 
+   abb = bb;
+   agsi = gsi;
+@@ -933,6 +934,8 @@ find_tail_calls (basic_block bb, struct
+ 	{
+ 	  edge e = single_non_eh_succ_edge (abb);
+ 	  ass_var = propagate_through_phis (ass_var, e);
++	  if (!ass_var)
++	    edges.safe_push (e);
+ 	  abb = e->dest;
+ 	  agsi = gsi_start_bb (abb);
+ 	}
+@@ -1040,9 +1043,7 @@ find_tail_calls (basic_block bb, struct
+       /* If IPA-VRP proves called function always returns a singleton range,
+ 	 the return value is replaced by the only value in that range.
+ 	 For tail call purposes, pretend such replacement didn't happen.  */
+-      if (ass_var == NULL_TREE
+-	  && !tail_recursion
+-	  && TREE_CONSTANT (ret_var))
++      if (ass_var == NULL_TREE && !tail_recursion)
+ 	if (tree type = gimple_range_type (call))
+ 	  if (tree callee = gimple_call_fndecl (call))
+ 	    if ((INTEGRAL_TYPE_P (type)
+@@ -1052,9 +1053,43 @@ find_tail_calls (basic_block bb, struct
+ 					      type)
+ 		&& useless_type_conversion_p (TREE_TYPE (ret_var), type)
+ 		&& ipa_return_value_range (val, callee)
+-		&& val.singleton_p (&valr)
+-		&& operand_equal_p (ret_var, valr, 0))
+-	      ok = true;
++		&& val.singleton_p (&valr))
++	      {
++		tree rv = ret_var;
++		unsigned int i = edges.length ();
++		/* If ret_var is equal to valr, we can tail optimize.  */
++		if (operand_equal_p (ret_var, valr, 0))
++		  ok = true;
++		else
++		  /* Otherwise, if ret_var is a PHI result, try to find out
++		     if valr isn't propagated through PHIs on the path from
++		     call's bb to SSA_NAME_DEF_STMT (ret_var)'s bb.  */
++		  while (TREE_CODE (rv) == SSA_NAME
++			 && gimple_code (SSA_NAME_DEF_STMT (rv)) == GIMPLE_PHI)
++		    {
++		      tree nrv = NULL_TREE;
++		      gimple *g = SSA_NAME_DEF_STMT (rv);
++		      for (; i; --i)
++			{
++			  if (edges[i - 1]->dest == gimple_bb (g))
++			    {
++			      nrv
++				= gimple_phi_arg_def_from_edge (g,
++								edges[i - 1]);
++			      --i;
++			      break;
++			    }
++			}
++		      if (nrv == NULL_TREE)
++			break;
++		      if (operand_equal_p (nrv, valr, 0))
++			{
++			  ok = true;
++			  break;
++			}
++		      rv = nrv;
++		    }
++	      }
+       if (!ok)
+ 	{
+ 	  maybe_error_musttail (call,
+--- a/gcc/testsuite/g++.dg/opt/pr119613.C	2025-04-04 20:51:42.482706589 +0200
++++ b/gcc/testsuite/g++.dg/opt/pr119613.C	2025-04-05 14:57:31.157353618 +0200
+@@ -1,5 +1,5 @@
+ // PR middle-end/119613
+-// { dg-do compile { target { musttail && { c || c++11 } } } }
++// { dg-do compile { target { musttail && c++11 } } }
+ // { dg-options "-O0" }
+ 
+ struct S { S () {} };
+--- a/gcc/testsuite/g++.dg/opt/pr119614.C	2025-04-05 14:57:16.276551780 +0200
++++ b/gcc/testsuite/g++.dg/opt/pr119614.C	2025-04-05 14:56:46.020954674 +0200
+@@ -0,0 +1,30 @@
++// PR tree-optimization/119614
++// { dg-do compile { target musttail } }
++// { dg-options "-O2" }
++
++struct S {} b;
++char *foo ();
++int e, g;
++void bar ();
++void corge (S);
++
++[[gnu::noinline]] char *
++baz ()
++{
++  bar ();
++  return 0;
++}
++
++const char *
++qux ()
++{
++  if (e)
++    {
++      S a = b;
++      corge (a);
++      if (g)
++        return 0;
++      [[gnu::musttail]] return baz ();
++    }
++  return foo ();
++}
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-06 23:08 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-06 23:08 UTC (permalink / raw
  To: gentoo-commits
commit:     a66a5c06524b0ef44ab17a89dd4eb7a3a135d4c2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Apr  6 23:07:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Apr  6 23:07:27 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=a66a5c06
15.0.0: cut patchset 53
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 4aed196..7255415 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,8 @@
-52	4 Aprli 2025
+53	7 April 2025
+
+	+ 88_all_PR119614.patch
+
+52	4 April 2025
 
 	+ 83_all_combine-Allow-2-2-combinations-but-with-a-tweak-PR11.patch
 	+ 84_all_combine-Avoid-split_i2i3-search-if-i2-is-unchanged-P.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-07  6:54 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-07  6:54 UTC (permalink / raw
  To: gentoo-commits
commit:     c4934edae0f83f1cee42d4890e01942ad17893f3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Apr  7 06:54:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Apr  7 06:54:46 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=c4934eda
15.0.0: refresh tail patch
No functional changes.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/88_all_PR119614.patch | 161 +++++++++++++++++++++++++-----------
 15.0.0/gentoo/README.history        |   4 +
 2 files changed, 115 insertions(+), 50 deletions(-)
diff --git a/15.0.0/gentoo/88_all_PR119614.patch b/15.0.0/gentoo/88_all_PR119614.patch
index e577f8f..753002f 100644
--- a/15.0.0/gentoo/88_all_PR119614.patch
+++ b/15.0.0/gentoo/88_all_PR119614.patch
@@ -1,6 +1,49 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c12
+https://inbox.sourceware.org/gcc-patches/Z%2FNiBLuNG0iaDHwi@tucnak/
 
-2025-04-05  Jakub Jelinek  <jakub@redhat.com>
+From de8e860faaee40f7f34a66440e8f98ed97219a89 Mon Sep 17 00:00:00 2001
+Message-ID: <de8e860faaee40f7f34a66440e8f98ed97219a89.1744008820.git.sam@gentoo.org>
+From: Jakub Jelinek <jakub@redhat.com>
+Date: Mon, 7 Apr 2025 07:26:28 +0200
+Subject: [PATCH] tailc: Extend the IPA-VRP workaround [PR119614]
+
+Hi!
+
+The IPA-VRP workaround in the tailc/musttail passes was just comparing
+the singleton constant from a tail call candidate return with the ret_val.
+This unfortunately doesn't work in the following testcase, where we have
+  <bb 5> [local count: 152205050]:
+  baz (); [must tail call]
+  goto <bb 4>; [100.00%]
+
+  <bb 6> [local count: 762356696]:
+  _8 = foo ();
+
+  <bb 7> [local count: 1073741824]:
+  # _3 = PHI <0B(4), _8(6)>
+  return _3;
+and in the unreduced testcase even more PHIs before we reach the return
+stmt.
+
+Normally when the call has lhs, whenever we follow a (non-EH) successor
+edge, it calls propagate_through_phis and that walks the PHIs in the
+destination bb of the edge and when it sees a PHI whose argument matches
+that of the currently tracked value (ass_var), it updates ass_var to
+PHI result of that PHI.  I think it is theoretically dangerous that it
+picks the first one, perhaps there could be multiple PHIs, so perhaps safer
+would be walk backwards from the return value up to the call.
+
+Anyway, this PR is about the IPA-VRP workaround, there ass_var is NULL
+because the potential tail call has no lhs, but ret_var is not TREE_CONSTANT
+but SSA_NAME with PHI as SSA_NAME_DEF_STMT.  The following patch handles
+it by pushing the edges we've walked through when ass_var is NULL into a
+vector and if ret_var is SSA_NAME set to PHI result, it attempts to walk
+back from the ret_var through arguments of PHIs corresponding to the
+edges we've walked back until we reach a constant and compare that constant
+against the singleton value as well.
+
+Bootstrapped/regtested on x86_64-linux and i686-linux, ok for trunk?
+
+2025-04-07  Jakub Jelinek  <jakub@redhat.com>
 
 	PR tree-optimization/119614
 	* tree-tailcall.cc (find_tail_calls): Remember edges which have been
@@ -12,10 +55,65 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c12
 	* g++.dg/opt/pr119613.C: Change { c || c++11 } in obviously C++ only
 	test to just c++11.
 	* g++.dg/opt/pr119614.C: New test.
+---
+ gcc/testsuite/g++.dg/opt/pr119613.C |  2 +-
+ gcc/testsuite/g++.dg/opt/pr119614.C | 30 ++++++++++++++++++
+ gcc/tree-tailcall.cc                | 47 +++++++++++++++++++++++++----
+ 3 files changed, 72 insertions(+), 7 deletions(-)
+ create mode 100644 gcc/testsuite/g++.dg/opt/pr119614.C
 
---- a/gcc/tree-tailcall.cc	2025-04-04 20:52:34.450015821 +0200
-+++ b/gcc/tree-tailcall.cc	2025-04-05 14:50:50.106693562 +0200
-@@ -920,6 +920,7 @@ find_tail_calls (basic_block bb, struct
+diff --git a/gcc/testsuite/g++.dg/opt/pr119613.C b/gcc/testsuite/g++.dg/opt/pr119613.C
+index 432a30cdcdb0..2ced2e8fa2a0 100644
+--- a/gcc/testsuite/g++.dg/opt/pr119613.C
++++ b/gcc/testsuite/g++.dg/opt/pr119613.C
+@@ -1,5 +1,5 @@
+ // PR middle-end/119613
+-// { dg-do compile { target { musttail && { c || c++11 } } } }
++// { dg-do compile { target { musttail && c++11 } } }
+ // { dg-options "-O0" }
+ 
+ struct S { S () {} };
+diff --git a/gcc/testsuite/g++.dg/opt/pr119614.C b/gcc/testsuite/g++.dg/opt/pr119614.C
+new file mode 100644
+index 000000000000..cb73fc3ec09d
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/opt/pr119614.C
+@@ -0,0 +1,30 @@
++// PR tree-optimization/119614
++// { dg-do compile { target musttail } }
++// { dg-options "-O2" }
++
++struct S {} b;
++char *foo ();
++int e, g;
++void bar ();
++void corge (S);
++
++[[gnu::noinline]] char *
++baz ()
++{
++  bar ();
++  return 0;
++}
++
++const char *
++qux ()
++{
++  if (e)
++    {
++      S a = b;
++      corge (a);
++      if (g)
++        return 0;
++      [[gnu::musttail]] return baz ();
++    }
++  return foo ();
++}
+diff --git a/gcc/tree-tailcall.cc b/gcc/tree-tailcall.cc
+index c8740f9353e2..f51bb970e329 100644
+--- a/gcc/tree-tailcall.cc
++++ b/gcc/tree-tailcall.cc
+@@ -920,6 +920,7 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
    auto_bitmap to_move_defs;
    auto_vec<gimple *> to_move_stmts;
    bool is_noreturn = gimple_call_noreturn_p (call);
@@ -23,7 +121,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c12
  
    abb = bb;
    agsi = gsi;
-@@ -933,6 +934,8 @@ find_tail_calls (basic_block bb, struct
+@@ -933,6 +934,8 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
  	{
  	  edge e = single_non_eh_succ_edge (abb);
  	  ass_var = propagate_through_phis (ass_var, e);
@@ -32,7 +130,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c12
  	  abb = e->dest;
  	  agsi = gsi_start_bb (abb);
  	}
-@@ -1040,9 +1043,7 @@ find_tail_calls (basic_block bb, struct
+@@ -1040,9 +1043,7 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
        /* If IPA-VRP proves called function always returns a singleton range,
  	 the return value is replaced by the only value in that range.
  	 For tail call purposes, pretend such replacement didn't happen.  */
@@ -43,7 +141,7 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c12
  	if (tree type = gimple_range_type (call))
  	  if (tree callee = gimple_call_fndecl (call))
  	    if ((INTEGRAL_TYPE_P (type)
-@@ -1052,9 +1053,43 @@ find_tail_calls (basic_block bb, struct
+@@ -1052,9 +1053,43 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
  					      type)
  		&& useless_type_conversion_p (TREE_TYPE (ret_var), type)
  		&& ipa_return_value_range (val, callee)
@@ -90,45 +188,8 @@ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c12
        if (!ok)
  	{
  	  maybe_error_musttail (call,
---- a/gcc/testsuite/g++.dg/opt/pr119613.C	2025-04-04 20:51:42.482706589 +0200
-+++ b/gcc/testsuite/g++.dg/opt/pr119613.C	2025-04-05 14:57:31.157353618 +0200
-@@ -1,5 +1,5 @@
- // PR middle-end/119613
--// { dg-do compile { target { musttail && { c || c++11 } } } }
-+// { dg-do compile { target { musttail && c++11 } } }
- // { dg-options "-O0" }
- 
- struct S { S () {} };
---- a/gcc/testsuite/g++.dg/opt/pr119614.C	2025-04-05 14:57:16.276551780 +0200
-+++ b/gcc/testsuite/g++.dg/opt/pr119614.C	2025-04-05 14:56:46.020954674 +0200
-@@ -0,0 +1,30 @@
-+// PR tree-optimization/119614
-+// { dg-do compile { target musttail } }
-+// { dg-options "-O2" }
-+
-+struct S {} b;
-+char *foo ();
-+int e, g;
-+void bar ();
-+void corge (S);
-+
-+[[gnu::noinline]] char *
-+baz ()
-+{
-+  bar ();
-+  return 0;
-+}
-+
-+const char *
-+qux ()
-+{
-+  if (e)
-+    {
-+      S a = b;
-+      corge (a);
-+      if (g)
-+        return 0;
-+      [[gnu::musttail]] return baz ();
-+    }
-+  return foo ();
-+}
+
+base-commit: 8fbe7d24373556d40886c7c00e9e2be5d9718c55
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 7255415..20d64c4 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,7 @@
+54	????
+
+	U 88_all_PR119614.patch
+
 53	7 April 2025
 
 	+ 88_all_PR119614.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-07  7:07 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-07  7:07 UTC (permalink / raw
  To: gentoo-commits
commit:     8cd7b247ed5101dbf81e3bf761f15207319aa2d4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Apr  7 07:07:29 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Apr  7 07:07:29 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=8cd7b247
15.0.0: drop combine patches merged upstream
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...ow-2-2-combinations-but-with-a-tweak-PR11.patch | 204 ------------------
 ...id-split_i2i3-search-if-i2-is-unchanged-P.patch |  54 -----
 ...Optimise-distribute_links-search-PR116398.patch |  99 ---------
 ...it-insn-searchs-for-2-2-combinations-PR11.patch | 240 ---------------------
 ...implify-rtx-Fix-shortcut-for-vector-eq-ne.patch | 131 -----------
 15.0.0/gentoo/README.history                       |   5 +
 6 files changed, 5 insertions(+), 728 deletions(-)
diff --git a/15.0.0/gentoo/83_all_combine-Allow-2-2-combinations-but-with-a-tweak-PR11.patch b/15.0.0/gentoo/83_all_combine-Allow-2-2-combinations-but-with-a-tweak-PR11.patch
deleted file mode 100644
index fd85bcd..0000000
--- a/15.0.0/gentoo/83_all_combine-Allow-2-2-combinations-but-with-a-tweak-PR11.patch
+++ /dev/null
@@ -1,204 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/mptecy8xowo.fsf@arm.com/
-
-From de2f5e9c4ce4bb674fb0da191102838a6bdd92f6 Mon Sep 17 00:00:00 2001
-Message-ID: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
-From: Richard Sandiford <richard.sandiford@arm.com>
-Date: Fri, 4 Apr 2025 10:21:43 +0100
-Subject: [PATCH 1/4] combine: Allow 2->2 combinations, but with a tweak
- [PR116398]
-
-One of the problems in PR101523 was that, after each successful
-2->2 combination attempt, try_combine would restart combination
-attempts at i2 even if i2 hadn't changed.  This led to quadratic
-behaviour as the same failed combinations between i2 and i3 were
-tried repeatedly.
-
-The original patch for the PR dealt with that by disallowing 2->2
-combinations.  However, that led to various optimisation regressions,
-so there was interest in allowing the combinations again, at least
-until an alternative way of getting the same results is in place.
-
-This patch is a variant of Richi's in:
-
-  https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101523#c53
-
-but limited to when we're combining 2 instructions.
-
-This speeds up combine by 10x on the original PR101523 testcase
-and reduces combine's memory footprint by 100x.
-
-gcc/
-	PR testsuite/116398
-	* combine.cc (try_combine): Reallow 2->2 combinations.  Detect when
-	only i3 has changed and restart from i3 in that case.
-
-gcc/testsuite/
-	* gcc.target/aarch64/popcnt-le-1.c: Account for commutativity of TST.
-	* gcc.target/aarch64/popcnt-le-3.c: Likewise AND.
-	* gcc.target/aarch64/sve/pred-not-gen-1.c: Revert previous patch.
-	* gcc.target/aarch64/sve/pred-not-gen-4.c: Likewise.
-	* gcc.target/aarch64/sve/var_stride_2.c: Likewise.
-	* gcc.target/aarch64/sve/var_stride_4.c: Likewise.
-
-Co-authored-by: Richard Biener <rguenther@suse.de>
----
- gcc/combine.cc                                     | 14 ++++----------
- gcc/testsuite/gcc.target/aarch64/popcnt-le-1.c     |  4 ++--
- gcc/testsuite/gcc.target/aarch64/popcnt-le-3.c     |  4 ++--
- gcc/testsuite/gcc.target/aarch64/pr100056.c        |  4 +++-
- .../gcc.target/aarch64/sve/pred-not-gen-1.c        |  4 ++--
- .../gcc.target/aarch64/sve/pred-not-gen-4.c        |  4 ++--
- .../gcc.target/aarch64/sve/var_stride_2.c          |  3 ++-
- .../gcc.target/aarch64/sve/var_stride_4.c          |  3 ++-
- 8 files changed, 19 insertions(+), 21 deletions(-)
-
-diff --git a/gcc/combine.cc b/gcc/combine.cc
-index 1b6c4e314cc9..65a87a45b3be 100644
---- a/gcc/combine.cc
-+++ b/gcc/combine.cc
-@@ -4210,16 +4210,7 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
-       adjust_for_new_dest (i3);
-     }
- 
--  /* If I2 didn't change, this is not a combination (but a simplification or
--     canonicalisation with context), which should not be done here.  Doing
--     it here explodes the algorithm.  Don't.  */
--  if (rtx_equal_p (newi2pat, PATTERN (i2)))
--    {
--      if (dump_file)
--	fprintf (dump_file, "i2 didn't change, not doing this\n");
--      undo_all ();
--      return 0;
--    }
-+  bool only_i3_changed = !i0 && !i1 && rtx_equal_p (newi2pat, PATTERN (i2));
- 
-   /* We now know that we can do this combination.  Merge the insns and
-      update the status of registers and LOG_LINKS.  */
-@@ -4787,6 +4778,9 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
-   combine_successes++;
-   undo_commit ();
- 
-+  if (only_i3_changed)
-+    return i3;
-+
-   rtx_insn *ret = newi2pat ? i2 : i3;
-   if (added_links_insn && DF_INSN_LUID (added_links_insn) < DF_INSN_LUID (ret))
-     ret = added_links_insn;
-diff --git a/gcc/testsuite/gcc.target/aarch64/popcnt-le-1.c b/gcc/testsuite/gcc.target/aarch64/popcnt-le-1.c
-index b4141da982c9..843fdac9fd8e 100644
---- a/gcc/testsuite/gcc.target/aarch64/popcnt-le-1.c
-+++ b/gcc/testsuite/gcc.target/aarch64/popcnt-le-1.c
-@@ -8,7 +8,7 @@
- /*
- ** le32:
- **	sub	w([0-9]+), w0, #1
--**	tst	w0, w\1
-+**	tst	(?:w0, w\1|w\1, w0)
- **	cset	w0, eq
- **	ret
- */
-@@ -20,7 +20,7 @@ unsigned le32 (const unsigned int a) {
- /*
- ** gt32:
- **	sub	w([0-9]+), w0, #1
--**	tst	w0, w\1
-+**	tst	(?:w0, w\1|w\1, w0)
- **	cset	w0, ne
- **	ret
- */
-diff --git a/gcc/testsuite/gcc.target/aarch64/popcnt-le-3.c b/gcc/testsuite/gcc.target/aarch64/popcnt-le-3.c
-index b811e6f6e8fe..3b558e95d819 100644
---- a/gcc/testsuite/gcc.target/aarch64/popcnt-le-3.c
-+++ b/gcc/testsuite/gcc.target/aarch64/popcnt-le-3.c
-@@ -8,7 +8,7 @@
- /*
- ** le16:
- **	sub	w([0-9]+), w0, #1
--**	and	w([0-9]+), w0, w\1
-+**	and	w([0-9]+), (?:w0, w\1|w\1, w0)
- **	tst	w\2, 65535
- **	cset	w0, eq
- **	ret
-@@ -21,7 +21,7 @@ unsigned le16 (const unsigned short a) {
- /*
- ** gt16:
- **	sub	w([0-9]+), w0, #1
--**	and	w([0-9]+), w0, w\1
-+**	and	w([0-9]+), (?:w0, w\1|w\1, w0)
- **	tst	w\2, 65535
- **	cset	w0, ne
- **	ret
-diff --git a/gcc/testsuite/gcc.target/aarch64/pr100056.c b/gcc/testsuite/gcc.target/aarch64/pr100056.c
-index 0b77824da457..70499772d285 100644
---- a/gcc/testsuite/gcc.target/aarch64/pr100056.c
-+++ b/gcc/testsuite/gcc.target/aarch64/pr100056.c
-@@ -1,7 +1,9 @@
- /* PR target/100056 */
- /* { dg-do compile } */
- /* { dg-options "-O2" } */
--/* { dg-final { scan-assembler-not {\t[us]bfiz\tw[0-9]+, w[0-9]+, 11} } } */
-+/* { dg-final { scan-assembler-not {\t[us]bfiz\tw[0-9]+, w[0-9]+, 11} { xfail *-*-* } } } */
-+/* { dg-final { scan-assembler-times {\t[us]bfiz\tw[0-9]+, w[0-9]+, 11} 2 } } */
-+/* { dg-final { scan-assembler-times {\tadd\tw[0-9]+, w[0-9]+, w[0-9]+, uxtb\n} 2 } } */
- 
- int
- or_shift_u8 (unsigned char i)
-diff --git a/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-1.c b/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-1.c
-index a7d2795ebe23..c9a8b82c48ac 100644
---- a/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-1.c
-+++ b/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-1.c
-@@ -19,6 +19,6 @@ void f10(double * restrict z, double * restrict w, double * restrict x, double *
-     }
- }
- 
--/* { dg-final { scan-assembler-not {\tbic\t} { xfail *-*-* } } } */
--/* { dg-final { scan-assembler-times {\tnot\tp[0-9]+\.b, p[0-9]+/z, p[0-9]+\.b\n} 1 { xfail *-*-* } } } */
-+/* { dg-final { scan-assembler-not {\tbic\t} } } */
-+/* { dg-final { scan-assembler-times {\tnot\tp[0-9]+\.b, p[0-9]+/z, p[0-9]+\.b\n} 1 } } */
- /* { dg-final { scan-assembler-times {\tfcmgt\tp[0-9]+\.d, p[0-9]+/z, z[0-9]+\.d, #0} 1 } } */
-diff --git a/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-4.c b/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-4.c
-index 20cbd7550b7e..1845bd3f0f70 100644
---- a/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-4.c
-+++ b/gcc/testsuite/gcc.target/aarch64/sve/pred-not-gen-4.c
-@@ -8,6 +8,6 @@ void f13(double * restrict z, double * restrict w, double * restrict x, double *
-     }
- }
- 
--/* { dg-final { scan-assembler-not {\tbic\t} { xfail *-*-* } } } */
--/* { dg-final { scan-assembler-times {\tnot\tp[0-9]+\.b, p[0-9]+/z, p[0-9]+\.b\n} 1 { xfail *-*-* } } } */
-+/* { dg-final { scan-assembler-not {\tbic\t} } } */
-+/* { dg-final { scan-assembler-times {\tnot\tp[0-9]+\.b, p[0-9]+/z, p[0-9]+\.b\n} 1 } } */
- /* { dg-final { scan-assembler-times {\tfcmuo\tp[0-9]+\.d, p[0-9]+/z, z[0-9]+\.d, z[0-9]+\.d} 1 } } */
-diff --git a/gcc/testsuite/gcc.target/aarch64/sve/var_stride_2.c b/gcc/testsuite/gcc.target/aarch64/sve/var_stride_2.c
-index 33b9f0f197e4..b8afea70207f 100644
---- a/gcc/testsuite/gcc.target/aarch64/sve/var_stride_2.c
-+++ b/gcc/testsuite/gcc.target/aarch64/sve/var_stride_2.c
-@@ -16,7 +16,8 @@ f (TYPE *x, TYPE *y, unsigned short n, unsigned short m)
- /* { dg-final { scan-assembler {\tldr\tw[0-9]+} } } */
- /* { dg-final { scan-assembler {\tstr\tw[0-9]+} } } */
- /* Should multiply by (257-1)*4 rather than (VF-1)*4 or (VF-2)*4.  */
--/* { dg-final { scan-assembler-times {\tadd\tx[0-9]+, x[0-9]+, x[0-9]+, lsl 10\n} 2 } } */
-+/* { dg-final { scan-assembler-times {\tubfiz\tx[0-9]+, x2, 10, 16\n} 1 } } */
-+/* { dg-final { scan-assembler-times {\tubfiz\tx[0-9]+, x3, 10, 16\n} 1 } } */
- /* { dg-final { scan-assembler-not {\tcmp\tx[0-9]+, 0} } } */
- /* { dg-final { scan-assembler-not {\tcmp\tw[0-9]+, 0} } } */
- /* { dg-final { scan-assembler-not {\tcsel\tx[0-9]+} } } */
-diff --git a/gcc/testsuite/gcc.target/aarch64/sve/var_stride_4.c b/gcc/testsuite/gcc.target/aarch64/sve/var_stride_4.c
-index 71b826a4c1bb..d2e74f9d4175 100644
---- a/gcc/testsuite/gcc.target/aarch64/sve/var_stride_4.c
-+++ b/gcc/testsuite/gcc.target/aarch64/sve/var_stride_4.c
-@@ -16,7 +16,8 @@ f (TYPE *x, TYPE *y, int n, int m)
- /* { dg-final { scan-assembler {\tldr\tw[0-9]+} } } */
- /* { dg-final { scan-assembler {\tstr\tw[0-9]+} } } */
- /* Should multiply by (257-1)*4 rather than (VF-1)*4.  */
--/* { dg-final { scan-assembler-times {\t(?:lsl\tx[0-9]+, x[0-9]+, 10|sbfiz\tx[0-9]+, x[0-9]+, 10, 32)\n} 2 } } */
-+/* { dg-final { scan-assembler-times {\tsbfiz\tx[0-9]+, x2, 10, 32\n} 1 } } */
-+/* { dg-final { scan-assembler-times {\tsbfiz\tx[0-9]+, x3, 10, 32\n} 1 } } */
- /* { dg-final { scan-assembler {\tcmp\tw2, 0} } } */
- /* { dg-final { scan-assembler {\tcmp\tw3, 0} } } */
- /* { dg-final { scan-assembler-times {\tcsel\tx[0-9]+} 4 } } */
-
-base-commit: d25728c98682c058bfda79333c94b0a8cf2a3f49
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/84_all_combine-Avoid-split_i2i3-search-if-i2-is-unchanged-P.patch b/15.0.0/gentoo/84_all_combine-Avoid-split_i2i3-search-if-i2-is-unchanged-P.patch
deleted file mode 100644
index 19d4917..0000000
--- a/15.0.0/gentoo/84_all_combine-Avoid-split_i2i3-search-if-i2-is-unchanged-P.patch
+++ /dev/null
@@ -1,54 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/mptecy8xowo.fsf@arm.com/
-
-From fac8faddc3fca52b6d51c0d1a57323012a1fe4e9 Mon Sep 17 00:00:00 2001
-Message-ID: <fac8faddc3fca52b6d51c0d1a57323012a1fe4e9.1743793443.git.sam@gentoo.org>
-In-Reply-To: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
-References: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
-From: Richard Sandiford <richard.sandiford@arm.com>
-Date: Fri, 4 Apr 2025 10:22:12 +0100
-Subject: [PATCH 2/4] combine: Avoid split_i2i3 search if i2 is unchanged
- [PR116398]
-
-When combining a single-set i2 into a multi-set i3, combine
-first tries to match the new multi-set in-place.  If that fails,
-combine considers splitting the multi-set so that one set goes in
-i2 and the other set stays in i3.  That moves a destination from i3
-to i2 and so combine needs to update any associated log link for that
-destination to point to i2 rather than i3.
-
-However, that kind of split can also occur for 2->2 combinations.
-For a 2-instruction combination in which i2 doesn't die in i3, combine
-tries a 2->1 combination by turning i3 into a parallel of the original
-i2 and the combined i3.  If that fails, combine will split the parallel
-as above, so that the first set goes in i2 and the second set goes in i3.
-But that can often leave i2 unchanged, meaning that no destinations have
-moved and so no search is necessary.
-
-gcc/
-	PR testsuite/116398
-	* combine.cc (try_combine): Shortcut the split_i2i3 handling if
-	i2 is unchanged.
----
- gcc/combine.cc | 6 ++++++
- 1 file changed, 6 insertions(+)
-
-diff --git a/gcc/combine.cc b/gcc/combine.cc
-index 65a87a45b3be..e29cff7147d9 100644
---- a/gcc/combine.cc
-+++ b/gcc/combine.cc
-@@ -4212,6 +4212,12 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
- 
-   bool only_i3_changed = !i0 && !i1 && rtx_equal_p (newi2pat, PATTERN (i2));
- 
-+  /* If only i3 has changed, any split of the combined instruction just
-+     restored i2 to its original state.  No destinations moved from i3
-+     to i2.  */
-+  if (only_i3_changed)
-+    split_i2i3 = false;
-+
-   /* We now know that we can do this combination.  Merge the insns and
-      update the status of registers and LOG_LINKS.  */
- 
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/85_all_combine-Optimise-distribute_links-search-PR116398.patch b/15.0.0/gentoo/85_all_combine-Optimise-distribute_links-search-PR116398.patch
deleted file mode 100644
index f8849ba..0000000
--- a/15.0.0/gentoo/85_all_combine-Optimise-distribute_links-search-PR116398.patch
+++ /dev/null
@@ -1,99 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/mptecy8xowo.fsf@arm.com/
-
-From bc27a2f371602bf897ff4da1620a56eeeeebf8ff Mon Sep 17 00:00:00 2001
-Message-ID: <bc27a2f371602bf897ff4da1620a56eeeeebf8ff.1743793443.git.sam@gentoo.org>
-In-Reply-To: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
-References: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
-From: Richard Sandiford <richard.sandiford@arm.com>
-Date: Fri, 4 Apr 2025 10:22:32 +0100
-Subject: [PATCH 3/4] combine: Optimise distribute_links search [PR116398]
-
-Another problem in PR101523 was that, after each successful 2->2
-combination attempt, distribute_links would search further and further
-for the next combinable use of the i2 destination.  Each search would
-start at i2 itself, making the search quadratic in the worst case.
-
-In a 2->2 combination, if i2 is unchanged, the search can start at i3
-instead of i2.  The same thing applies to i2 when distributing i2's
-links, since the only changes to earlier instructions are the deletion
-of i0 and i1.
-
-This change, combined with the previous split_i2i3 patch, gives a
-34.6% speedup in combine for the testcase in PR101523.  Combine
-goes from being 41% to 34% of compile time.
-
-gcc/
-	PR testsuite/116398
-	* combine.cc (distribute_links): Take an optional start point.
-	(try_combine): If only i3 has changed, only distribute i3's links,
-	not i2's.  Start the search for the new use from i3 rather than
-	from the definition instruction.  Likewise start the search for
-	the new use from i2 when distributing i2's links.
----
- gcc/combine.cc | 27 +++++++++++++++++++--------
- 1 file changed, 19 insertions(+), 8 deletions(-)
-
-diff --git a/gcc/combine.cc b/gcc/combine.cc
-index e29cff7147d9..e99b064c98d4 100644
---- a/gcc/combine.cc
-+++ b/gcc/combine.cc
-@@ -472,7 +472,7 @@ static void move_deaths (rtx, rtx, int, rtx_insn *, rtx *);
- static bool reg_bitfield_target_p (rtx, rtx);
- static void distribute_notes (rtx, rtx_insn *, rtx_insn *, rtx_insn *,
- 			      rtx, rtx, rtx);
--static void distribute_links (struct insn_link *);
-+static void distribute_links (struct insn_link *, rtx_insn * = nullptr);
- static void mark_used_regs_combine (rtx);
- static void record_promoted_value (rtx_insn *, rtx);
- static bool unmentioned_reg_p (rtx, rtx);
-@@ -4592,10 +4592,15 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
- 			    NULL_RTX, NULL_RTX, NULL_RTX);
-       }
- 
--    distribute_links (i3links);
--    distribute_links (i2links);
--    distribute_links (i1links);
--    distribute_links (i0links);
-+    if (only_i3_changed)
-+      distribute_links (i3links, i3);
-+    else
-+      {
-+	distribute_links (i3links);
-+	distribute_links (i2links, i2);
-+	distribute_links (i1links);
-+	distribute_links (i0links);
-+      }
- 
-     if (REG_P (i2dest))
-       {
-@@ -14986,10 +14991,13 @@ distribute_notes (rtx notes, rtx_insn *from_insn, rtx_insn *i3, rtx_insn *i2,
- \f
- /* Similarly to above, distribute the LOG_LINKS that used to be present on
-    I3, I2, and I1 to new locations.  This is also called to add a link
--   pointing at I3 when I3's destination is changed.  */
-+   pointing at I3 when I3's destination is changed.
-+
-+   If START is nonnull and an insn, we know that the next location for each
-+   link is no earlier than START.  */
- 
- static void
--distribute_links (struct insn_link *links)
-+distribute_links (struct insn_link *links, rtx_insn *start)
- {
-   struct insn_link *link, *next_link;
- 
-@@ -15055,7 +15063,10 @@ distribute_links (struct insn_link *links)
- 	 I3 to I2.  Also note that not much searching is typically done here
- 	 since most links don't point very far away.  */
- 
--      for (insn = NEXT_INSN (link->insn);
-+      insn = start;
-+      if (!insn || NOTE_P (insn))
-+	insn = NEXT_INSN (link->insn);
-+      for (;
- 	   (insn && (this_basic_block->next_bb == EXIT_BLOCK_PTR_FOR_FN (cfun)
- 		     || BB_HEAD (this_basic_block->next_bb) != insn));
- 	   insn = NEXT_INSN (insn))
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch b/15.0.0/gentoo/86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch
deleted file mode 100644
index b185cba..0000000
--- a/15.0.0/gentoo/86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch
+++ /dev/null
@@ -1,240 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/mptecy8xowo.fsf@arm.com/
-
-From 247ac81832821bade9fa36c350d220dca039d383 Mon Sep 17 00:00:00 2001
-Message-ID: <247ac81832821bade9fa36c350d220dca039d383.1743793443.git.sam@gentoo.org>
-In-Reply-To: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
-References: <de2f5e9c4ce4bb674fb0da191102838a6bdd92f6.1743793443.git.sam@gentoo.org>
-From: Richard Sandiford <richard.sandiford@arm.com>
-Date: Fri, 4 Apr 2025 10:23:00 +0100
-Subject: [PATCH 4/4] combine: Limit insn searchs for 2->2 combinations
- [PR116398]
-
-As noted in the previous patch, combine still takes >30% of
-compile time in the original testcase for PR101523.  The problem
-is that try_combine uses linear insn searches for some dataflow
-queries, so in the worst case, an unlimited number of 2->2
-combinations for the same i2 can lead to quadratic behaviour.
-
-This patch limits distribute_links to a certain number
-of instructions when i2 is unchanged.  As Segher said in the PR trail,
-it would make more conceptual sense to apply the limit unconditionally,
-but I thought it would be better to change as little as possible at
-this development stage.  Logically, in stage 1, the --param should
-be applied directly by distribute_links with no input from callers.
-
-As I mentioned in:
-
-  https://gcc.gnu.org/bugzilla/show_bug.cgi?id=116398#c28
-
-I think it's safe to drop log links even if a use exists.  All
-processing of log links seems to handle the absence of a link
-for a particular register in a conservative way.
-
-The initial set-up errs on the side of dropping links, since for example
-create_log_links has:
-
-             /* flow.c claimed:
-
-                 We don't build a LOG_LINK for hard registers contained
-                 in ASM_OPERANDs.  If these registers get replaced,
-                 we might wind up changing the semantics of the insn,
-                 even if reload can make what appear to be valid
-                 assignments later.  */
-              if (regno < FIRST_PSEUDO_REGISTER
-                  && asm_noperands (PATTERN (use_insn)) >= 0)
-                continue;
-
-which excludes combinations by dropping log links, rather than during
-try_combine.  And:
-
-      /* If this register is being initialized using itself, and the
-         register is uninitialized in this basic block, and there are
-         no LOG_LINKS which set the register, then part of the
-         register is uninitialized.  In that case we can't assume
-         anything about the number of nonzero bits.
-
-         ??? We could do better if we checked this in
-         reg_{nonzero_bits,num_sign_bit_copies}_for_combine.  Then we
-         could avoid making assumptions about the insn which initially
-         sets the register, while still using the information in other
-         insns.  We would have to be careful to check every insn
-         involved in the combination.  */
-
-      if (insn
-          && reg_referenced_p (x, PATTERN (insn))
-          && !REGNO_REG_SET_P (DF_LR_IN (BLOCK_FOR_INSN (insn)),
-                               REGNO (x)))
-        {
-          struct insn_link *link;
-
-          FOR_EACH_LOG_LINK (link, insn)
-            if (dead_or_set_p (link->insn, x))
-              break;
-          if (!link)
-            {
-              rsp->nonzero_bits = GET_MODE_MASK (mode);
-              rsp->sign_bit_copies = 1;
-              return;
-            }
-        }
-
-treats the lack of a log link as a possible sign of uninitialised data,
-but that would be a missed optimisation rather than a correctness issue.
-
-One question is what the default --param value should be.  I went with
-Jakub's suggestion of 3000 from:
-
-  https://gcc.gnu.org/bugzilla/show_bug.cgi?id=116398#c25
-
-Also, to answer Jakub's question in that comment, I tried bisecting:
-
-  int limit = atoi (getenv ("BISECT"));
-
-(so applying the limit for all calls from try_combine) with an
-abort in distribute_links if the limit caused a link to be skipped.
-The minimum BISECT value that allowed an aarch64-linux-gnu bootstrap
-to succeed with --enable-languages=all --enable-checking=yes,rtl,extra
-was 142, so much lower than the parameter value.  I realised too late
-that --enable-checking=release would probably have been a more
-interesting test.
-
-The previous patch meant that distribute_links itself is now linear
-for a given i2 definition, since each search starts at the previous
-last use, rather than at i2 itself.  This means that the limit has
-to be applied cumulatively across all searches for the same link.
-
-The patch does that by storing a counter in the insn_link structure.
-There was a 32-bit hole there on LP64 hosts.
-
-gcc/
-	PR testsuite/116398
-	* params.opt (-param=max-combine-search-insns=): New param.
-	* doc/invoke.texi: Document it.
-	* combine.cc (insn_link::insn_count): New field.
-	(alloc_insn_link): Initialize it.
-	(distribute_links): Add a limit parameter.
-	(try_combine): Use the new param to limit distribute_links
-	when only i3 has changed.
----
- gcc/combine.cc      | 21 +++++++++++++++++----
- gcc/doc/invoke.texi |  9 +++++++++
- gcc/params.opt      |  4 ++++
- 3 files changed, 30 insertions(+), 4 deletions(-)
-
-diff --git a/gcc/combine.cc b/gcc/combine.cc
-index e99b064c98d4..5f085187cfef 100644
---- a/gcc/combine.cc
-+++ b/gcc/combine.cc
-@@ -309,6 +309,7 @@ static int *uid_insn_cost;
- struct insn_link {
-   rtx_insn *insn;
-   unsigned int regno;
-+  int insn_count;
-   struct insn_link *next;
- };
- 
-@@ -342,6 +343,7 @@ alloc_insn_link (rtx_insn *insn, unsigned int regno, struct insn_link *next)
- 					  sizeof (struct insn_link));
-   l->insn = insn;
-   l->regno = regno;
-+  l->insn_count = 0;
-   l->next = next;
-   return l;
- }
-@@ -472,7 +474,8 @@ static void move_deaths (rtx, rtx, int, rtx_insn *, rtx *);
- static bool reg_bitfield_target_p (rtx, rtx);
- static void distribute_notes (rtx, rtx_insn *, rtx_insn *, rtx_insn *,
- 			      rtx, rtx, rtx);
--static void distribute_links (struct insn_link *, rtx_insn * = nullptr);
-+static void distribute_links (struct insn_link *, rtx_insn * = nullptr,
-+			      int limit = INT_MAX);
- static void mark_used_regs_combine (rtx);
- static void record_promoted_value (rtx_insn *, rtx);
- static bool unmentioned_reg_p (rtx, rtx);
-@@ -4593,7 +4596,7 @@ try_combine (rtx_insn *i3, rtx_insn *i2, rtx_insn *i1, rtx_insn *i0,
-       }
- 
-     if (only_i3_changed)
--      distribute_links (i3links, i3);
-+      distribute_links (i3links, i3, param_max_combine_search_insns);
-     else
-       {
- 	distribute_links (i3links);
-@@ -14994,10 +14997,12 @@ distribute_notes (rtx notes, rtx_insn *from_insn, rtx_insn *i3, rtx_insn *i2,
-    pointing at I3 when I3's destination is changed.
- 
-    If START is nonnull and an insn, we know that the next location for each
--   link is no earlier than START.  */
-+   link is no earlier than START.  LIMIT is the maximum number of nondebug
-+   instructions that can be scanned when looking for the next use of a
-+   definition.  */
- 
- static void
--distribute_links (struct insn_link *links, rtx_insn *start)
-+distribute_links (struct insn_link *links, rtx_insn *start, int limit)
- {
-   struct insn_link *link, *next_link;
- 
-@@ -15063,9 +15068,12 @@ distribute_links (struct insn_link *links, rtx_insn *start)
- 	 I3 to I2.  Also note that not much searching is typically done here
- 	 since most links don't point very far away.  */
- 
-+      int count = 0;
-       insn = start;
-       if (!insn || NOTE_P (insn))
- 	insn = NEXT_INSN (link->insn);
-+      else
-+	count = link->insn_count;
-       for (;
- 	   (insn && (this_basic_block->next_bb == EXIT_BLOCK_PTR_FOR_FN (cfun)
- 		     || BB_HEAD (this_basic_block->next_bb) != insn));
-@@ -15086,6 +15094,11 @@ distribute_links (struct insn_link *links, rtx_insn *start)
- 	  }
- 	else if (INSN_P (insn) && reg_set_p (reg, insn))
- 	  break;
-+	else if (count >= limit)
-+	  break;
-+	else
-+	  count += 1;
-+      link->insn_count = count;
- 
-       /* If we found a place to put the link, place it there unless there
- 	 is already a link to the same insn as LINK at that point.  */
-diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
-index 4c9af429ab08..0903cd2b7f23 100644
---- a/gcc/doc/invoke.texi
-+++ b/gcc/doc/invoke.texi
-@@ -16518,6 +16518,15 @@ in combiner for a pseudo register as last known value of that register.
- @item max-combine-insns
- The maximum number of instructions the RTL combiner tries to combine.
- 
-+@item max-combine-search-insns
-+The maximum number of instructions that the RTL combiner searches in order
-+to find the next use of a given register definition.  If this limit is reached
-+without finding such a use, the combiner will stop trying to optimize the
-+definition.
-+
-+Currently this limit only applies after certain successful combination
-+attempts, but it could be extended to other cases in future.
-+
- @item integer-share-limit
- Small integer constants can use a shared data structure, reducing the
- compiler's memory usage and increasing its speed.  This sets the maximum
-diff --git a/gcc/params.opt b/gcc/params.opt
-index 4f4eb4d7a2a5..422d082b3557 100644
---- a/gcc/params.opt
-+++ b/gcc/params.opt
-@@ -477,6 +477,10 @@ The maximum number of instructions to consider to unroll in a loop on average.
- Common Joined UInteger Var(param_max_combine_insns) Init(4) IntegerRange(2, 4) Param Optimization
- The maximum number of insns combine tries to combine.
- 
-+-param=max-combine-search-insns=
-+Common Joined UInteger Var(param_max_combine_search_insns) Init(3000) Param Optimization
-+The maximum number of instructions that combine searches in order to find the next use of a particular register.
-+
- -param=max-completely-peel-loop-nest-depth=
- Common Joined UInteger Var(param_max_unroll_iterations) Init(8) Param Optimization
- The maximum depth of a loop nest we completely peel.
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch b/15.0.0/gentoo/87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch
deleted file mode 100644
index 76c3552..0000000
--- a/15.0.0/gentoo/87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch
+++ /dev/null
@@ -1,131 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/mpt7c443wm7.fsf@arm.com/
-
-From 5cc0c07a938202390b612f4e47934c09a17cad9a Mon Sep 17 00:00:00 2001
-Message-ID: <5cc0c07a938202390b612f4e47934c09a17cad9a.1743817315.git.sam@gentoo.org>
-From: Richard Sandiford <richard.sandiford@arm.com>
-Date: Tue, 1 Apr 2025 13:16:32 +0100
-Subject: [PATCH] simplify-rtx: Fix shortcut for vector eq/ne
-
-This patch forestalls a regression in gcc.dg/rtl/x86_64/vector_eq.c
-with the patch for PR116398.  The test wants:
-
-      (cinsn 3 (set (reg:V4SI <0>) (const_vector:V4SI [(const_int 0) (const_int 0) (const_int 0) (const_int 0)])))
-      (cinsn 5 (set (reg:V4SI <2>)
-		    (eq:V4SI (reg:V4SI <0>) (reg:V4SI <1>))))
-
-to be folded to a vector of -1s.  One unusual thing about the fold
-is that the <1> in the second insn is uninitialised; it looks like
-it should be replaced by <0>, or that there should be an insn 4 that
-copies <0> to <1>.
-
-As it stands, the test relies on init-regs to insert a zero
-initialisation of <1>.  This happens after all the cse/pre/fwprop
-stuff, with only dce passes between init-regs and combine.
-Combine therefore sees:
-
-(insn 3 2 8 2 (set (reg:V4SI 98)
-        (const_vector:V4SI [
-                (const_int 0 [0]) repeated x4
-            ])) 2403 {movv4si_internal}
-     (nil))
-(insn 8 3 9 2 (clobber (reg:V4SI 99)) -1
-     (nil))
-(insn 9 8 5 2 (set (reg:V4SI 99)
-        (const_vector:V4SI [
-                (const_int 0 [0]) repeated x4
-            ])) -1
-     (nil))
-(insn 5 9 7 2 (set (reg:V4SI 100)
-        (eq:V4SI (reg:V4SI 98)
-            (reg:V4SI 99))) 7874 {*sse2_eqv4si3}
-     (expr_list:REG_DEAD (reg:V4SI 99)
-        (expr_list:REG_DEAD (reg:V4SI 98)
-            (expr_list:REG_EQUAL (eq:V4SI (const_vector:V4SI [
-                            (const_int 0 [0]) repeated x4
-                        ])
-                    (reg:V4SI 99))
-                (nil)))))
-
-It looks like the test should then pass through a 3, 9 -> 5 combination,
-so that we get an (eq ...) between two zeros and fold it to a vector
-of -1s.  But although the combination is attempted, the fold doesn't
-happen.  Instead, combine is left to match the unsimplified (eq ...)
-between two zeros, which rightly fails.  The test only passes because
-late_combine2 happens to try simplifying an (eq ...) between reg X and
-reg X, which does fold to a vector of -1s.
-
-The different handling of registers and constants is due to this
-code in simplify_const_relational_operation:
-
-  if (INTEGRAL_MODE_P (mode) && trueop1 != const0_rtx
-      && (code == EQ || code == NE)
-      && ! ((REG_P (op0) || CONST_INT_P (trueop0))
-	    && (REG_P (op1) || CONST_INT_P (trueop1)))
-      && (tem = simplify_binary_operation (MINUS, mode, op0, op1)) != 0
-      /* We cannot do this if tem is a nonzero address.  */
-      && ! nonzero_address_p (tem))
-    return simplify_const_relational_operation (signed_condition (code),
-						mode, tem, const0_rtx);
-
-INTEGRAL_MODE_P matches vector integer modes, but everything else
-about the condition is written for scalar integers only.  Thus if
-trueop0 and trueop1 are equal vector constants, we'll bypass all
-the exclusions and try simplifying a subtraction.  This will succeed,
-giving a vector of zeros.  The recursive call will then try to simplify
-a comparison between the vector of zeros and const0_rtx, which isn't
-well-formed.  Luckily or unluckily, the ill-formedness doesn't trigger
-an ICE, but it does prevent any simplification from happening.
-
-The least-effort fix would be to replace INTEGRAL_MODE_P with
-SCALAR_INT_MODE_P.  But the fold does make conceptual sense for
-vectors too, so it seemed better to keep the INTEGRAL_MODE_P and
-generalise the rest of the condition to match.
-
-Tested on aarch64-linux-gnu & x86_64-linux-gnu.  OK to install?
-
-I'm hoping to post the actual patch for PR116398 later today.
-
-Richard
-
-gcc/
-	* simplify-rtx.cc (simplify_const_relational_operation): Generalize
-	the constant checks in the fold-via-minus path to match the
-	INTEGRAL_MODE_P condition.
----
- gcc/simplify-rtx.cc | 13 +++++++++----
- 1 file changed, 9 insertions(+), 4 deletions(-)
-
-diff --git a/gcc/simplify-rtx.cc b/gcc/simplify-rtx.cc
-index fe007bc7d96a..6f969effdf99 100644
---- a/gcc/simplify-rtx.cc
-+++ b/gcc/simplify-rtx.cc
-@@ -6657,15 +6657,20 @@ simplify_const_relational_operation (enum rtx_code code,
-      we do not know the signedness of the operation on either the left or
-      the right hand side of the comparison.  */
- 
--  if (INTEGRAL_MODE_P (mode) && trueop1 != const0_rtx
-+  if (INTEGRAL_MODE_P (mode)
-+      && trueop1 != CONST0_RTX (mode)
-       && (code == EQ || code == NE)
--      && ! ((REG_P (op0) || CONST_INT_P (trueop0))
--	    && (REG_P (op1) || CONST_INT_P (trueop1)))
-+      && ! ((REG_P (op0)
-+	     || CONST_SCALAR_INT_P (trueop0)
-+	     || CONST_VECTOR_P (trueop0))
-+	    && (REG_P (op1)
-+		|| CONST_SCALAR_INT_P (trueop1)
-+		|| CONST_VECTOR_P (trueop1)))
-       && (tem = simplify_binary_operation (MINUS, mode, op0, op1)) != 0
-       /* We cannot do this if tem is a nonzero address.  */
-       && ! nonzero_address_p (tem))
-     return simplify_const_relational_operation (signed_condition (code),
--						mode, tem, const0_rtx);
-+						mode, tem, CONST0_RTX (mode));
- 
-   if (! HONOR_NANS (mode) && code == ORDERED)
-     return const_true_rtx;
-
-base-commit: 2f62e66e1444d858e937faa7147f6cd06296b33b
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 20d64c4..51cd6a7 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,10 @@
 54	????
 
+	- 83_all_combine-Allow-2-2-combinations-but-with-a-tweak-PR11.patch
+	- 84_all_combine-Avoid-split_i2i3-search-if-i2-is-unchanged-P.patch
+	- 85_all_combine-Optimise-distribute_links-search-PR116398.patch
+	- 86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch
+	- 87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch
 	U 88_all_PR119614.patch
 
 53	7 April 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-07 18:02 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-07 18:02 UTC (permalink / raw
  To: gentoo-commits
commit:     3c997ffed4de1d98d745b63d1ef95342800c52f1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Apr  7 18:02:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Apr  7 18:02:01 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=3c997ffe
15.0.0: drop 88_all_PR119614.patch patch, merged upstream
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/88_all_PR119614.patch | 195 ------------------------------------
 15.0.0/gentoo/README.history        |   2 +-
 2 files changed, 1 insertion(+), 196 deletions(-)
diff --git a/15.0.0/gentoo/88_all_PR119614.patch b/15.0.0/gentoo/88_all_PR119614.patch
deleted file mode 100644
index 753002f..0000000
--- a/15.0.0/gentoo/88_all_PR119614.patch
+++ /dev/null
@@ -1,195 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/Z%2FNiBLuNG0iaDHwi@tucnak/
-
-From de8e860faaee40f7f34a66440e8f98ed97219a89 Mon Sep 17 00:00:00 2001
-Message-ID: <de8e860faaee40f7f34a66440e8f98ed97219a89.1744008820.git.sam@gentoo.org>
-From: Jakub Jelinek <jakub@redhat.com>
-Date: Mon, 7 Apr 2025 07:26:28 +0200
-Subject: [PATCH] tailc: Extend the IPA-VRP workaround [PR119614]
-
-Hi!
-
-The IPA-VRP workaround in the tailc/musttail passes was just comparing
-the singleton constant from a tail call candidate return with the ret_val.
-This unfortunately doesn't work in the following testcase, where we have
-  <bb 5> [local count: 152205050]:
-  baz (); [must tail call]
-  goto <bb 4>; [100.00%]
-
-  <bb 6> [local count: 762356696]:
-  _8 = foo ();
-
-  <bb 7> [local count: 1073741824]:
-  # _3 = PHI <0B(4), _8(6)>
-  return _3;
-and in the unreduced testcase even more PHIs before we reach the return
-stmt.
-
-Normally when the call has lhs, whenever we follow a (non-EH) successor
-edge, it calls propagate_through_phis and that walks the PHIs in the
-destination bb of the edge and when it sees a PHI whose argument matches
-that of the currently tracked value (ass_var), it updates ass_var to
-PHI result of that PHI.  I think it is theoretically dangerous that it
-picks the first one, perhaps there could be multiple PHIs, so perhaps safer
-would be walk backwards from the return value up to the call.
-
-Anyway, this PR is about the IPA-VRP workaround, there ass_var is NULL
-because the potential tail call has no lhs, but ret_var is not TREE_CONSTANT
-but SSA_NAME with PHI as SSA_NAME_DEF_STMT.  The following patch handles
-it by pushing the edges we've walked through when ass_var is NULL into a
-vector and if ret_var is SSA_NAME set to PHI result, it attempts to walk
-back from the ret_var through arguments of PHIs corresponding to the
-edges we've walked back until we reach a constant and compare that constant
-against the singleton value as well.
-
-Bootstrapped/regtested on x86_64-linux and i686-linux, ok for trunk?
-
-2025-04-07  Jakub Jelinek  <jakub@redhat.com>
-
-	PR tree-optimization/119614
-	* tree-tailcall.cc (find_tail_calls): Remember edges which have been
-	walked through if !ass_var.  Perform IPA-VRP workaround even when
-	ret_var is not TREE_CONSTANT, in that case check in a loop if it is
-	a PHI result and in that case look at the PHI argument from
-	corresponding edge in the edge vector.
-
-	* g++.dg/opt/pr119613.C: Change { c || c++11 } in obviously C++ only
-	test to just c++11.
-	* g++.dg/opt/pr119614.C: New test.
----
- gcc/testsuite/g++.dg/opt/pr119613.C |  2 +-
- gcc/testsuite/g++.dg/opt/pr119614.C | 30 ++++++++++++++++++
- gcc/tree-tailcall.cc                | 47 +++++++++++++++++++++++++----
- 3 files changed, 72 insertions(+), 7 deletions(-)
- create mode 100644 gcc/testsuite/g++.dg/opt/pr119614.C
-
-diff --git a/gcc/testsuite/g++.dg/opt/pr119613.C b/gcc/testsuite/g++.dg/opt/pr119613.C
-index 432a30cdcdb0..2ced2e8fa2a0 100644
---- a/gcc/testsuite/g++.dg/opt/pr119613.C
-+++ b/gcc/testsuite/g++.dg/opt/pr119613.C
-@@ -1,5 +1,5 @@
- // PR middle-end/119613
--// { dg-do compile { target { musttail && { c || c++11 } } } }
-+// { dg-do compile { target { musttail && c++11 } } }
- // { dg-options "-O0" }
- 
- struct S { S () {} };
-diff --git a/gcc/testsuite/g++.dg/opt/pr119614.C b/gcc/testsuite/g++.dg/opt/pr119614.C
-new file mode 100644
-index 000000000000..cb73fc3ec09d
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/opt/pr119614.C
-@@ -0,0 +1,30 @@
-+// PR tree-optimization/119614
-+// { dg-do compile { target musttail } }
-+// { dg-options "-O2" }
-+
-+struct S {} b;
-+char *foo ();
-+int e, g;
-+void bar ();
-+void corge (S);
-+
-+[[gnu::noinline]] char *
-+baz ()
-+{
-+  bar ();
-+  return 0;
-+}
-+
-+const char *
-+qux ()
-+{
-+  if (e)
-+    {
-+      S a = b;
-+      corge (a);
-+      if (g)
-+        return 0;
-+      [[gnu::musttail]] return baz ();
-+    }
-+  return foo ();
-+}
-diff --git a/gcc/tree-tailcall.cc b/gcc/tree-tailcall.cc
-index c8740f9353e2..f51bb970e329 100644
---- a/gcc/tree-tailcall.cc
-+++ b/gcc/tree-tailcall.cc
-@@ -920,6 +920,7 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
-   auto_bitmap to_move_defs;
-   auto_vec<gimple *> to_move_stmts;
-   bool is_noreturn = gimple_call_noreturn_p (call);
-+  auto_vec<edge> edges;
- 
-   abb = bb;
-   agsi = gsi;
-@@ -933,6 +934,8 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
- 	{
- 	  edge e = single_non_eh_succ_edge (abb);
- 	  ass_var = propagate_through_phis (ass_var, e);
-+	  if (!ass_var)
-+	    edges.safe_push (e);
- 	  abb = e->dest;
- 	  agsi = gsi_start_bb (abb);
- 	}
-@@ -1040,9 +1043,7 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
-       /* If IPA-VRP proves called function always returns a singleton range,
- 	 the return value is replaced by the only value in that range.
- 	 For tail call purposes, pretend such replacement didn't happen.  */
--      if (ass_var == NULL_TREE
--	  && !tail_recursion
--	  && TREE_CONSTANT (ret_var))
-+      if (ass_var == NULL_TREE && !tail_recursion)
- 	if (tree type = gimple_range_type (call))
- 	  if (tree callee = gimple_call_fndecl (call))
- 	    if ((INTEGRAL_TYPE_P (type)
-@@ -1052,9 +1053,43 @@ find_tail_calls (basic_block bb, struct tailcall **ret, bool only_musttail,
- 					      type)
- 		&& useless_type_conversion_p (TREE_TYPE (ret_var), type)
- 		&& ipa_return_value_range (val, callee)
--		&& val.singleton_p (&valr)
--		&& operand_equal_p (ret_var, valr, 0))
--	      ok = true;
-+		&& val.singleton_p (&valr))
-+	      {
-+		tree rv = ret_var;
-+		unsigned int i = edges.length ();
-+		/* If ret_var is equal to valr, we can tail optimize.  */
-+		if (operand_equal_p (ret_var, valr, 0))
-+		  ok = true;
-+		else
-+		  /* Otherwise, if ret_var is a PHI result, try to find out
-+		     if valr isn't propagated through PHIs on the path from
-+		     call's bb to SSA_NAME_DEF_STMT (ret_var)'s bb.  */
-+		  while (TREE_CODE (rv) == SSA_NAME
-+			 && gimple_code (SSA_NAME_DEF_STMT (rv)) == GIMPLE_PHI)
-+		    {
-+		      tree nrv = NULL_TREE;
-+		      gimple *g = SSA_NAME_DEF_STMT (rv);
-+		      for (; i; --i)
-+			{
-+			  if (edges[i - 1]->dest == gimple_bb (g))
-+			    {
-+			      nrv
-+				= gimple_phi_arg_def_from_edge (g,
-+								edges[i - 1]);
-+			      --i;
-+			      break;
-+			    }
-+			}
-+		      if (nrv == NULL_TREE)
-+			break;
-+		      if (operand_equal_p (nrv, valr, 0))
-+			{
-+			  ok = true;
-+			  break;
-+			}
-+		      rv = nrv;
-+		    }
-+	      }
-       if (!ok)
- 	{
- 	  maybe_error_musttail (call,
-
-base-commit: 8fbe7d24373556d40886c7c00e9e2be5d9718c55
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 51cd6a7..c3166a6 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -5,7 +5,7 @@
 	- 85_all_combine-Optimise-distribute_links-search-PR116398.patch
 	- 86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch
 	- 87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch
-	U 88_all_PR119614.patch
+	- 88_all_PR119614.patch
 
 53	7 April 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-09 12:42 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-09 12:42 UTC (permalink / raw
  To: gentoo-commits
commit:     7fdeb3bbc747e8fca508703af93d3af5d7feb81e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  9 12:42:48 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr  9 12:42:48 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=7fdeb3bb
15.0.0: add compare-debug patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/83_all_PR119689.patch | 100 ++++++++++++++++++++++++++++++++++++
 15.0.0/gentoo/README.history        |   1 +
 2 files changed, 101 insertions(+)
diff --git a/15.0.0/gentoo/83_all_PR119689.patch b/15.0.0/gentoo/83_all_PR119689.patch
new file mode 100644
index 0000000..aaa1307
--- /dev/null
+++ b/15.0.0/gentoo/83_all_PR119689.patch
@@ -0,0 +1,100 @@
+https://inbox.sourceware.org/gcc-patches/20250409124018.R4J_6bGlxGGDb4MRmq3_nKa5BMDlxJ9RZybNrpR3J58@z/
+
+From 83b08e26be60bd1fd03323643f6c75e46b5cc0fd Mon Sep 17 00:00:00 2001
+Message-ID: <83b08e26be60bd1fd03323643f6c75e46b5cc0fd.1744202504.git.sam@gentoo.org>
+From: Richard Biener <rguenther@suse.de>
+Date: Wed, 9 Apr 2025 14:40:18 +0200
+Subject: [PATCH] rtl-optimization/119689 - compare-debug failure with LRA
+
+The previous change to fix LRA rematerialization broke compare-debug
+for i586 bootstrap.  Fixed by using prev_nonnote_nondebug_insn
+instead of prev_nonnote_insn.
+
+Bootstrapped on i586-linux where the miscompare is gone with this
+patch.  Bootstrap and regtest running on x86_64-unknown-linux-gnu.
+
+OK if the latter succeeds?
+
+Thanks,
+Richard.
+
+	PR rtl-optimization/119689
+	PR rtl-optimization/115568
+	* lra-remat.cc (create_cands): Use prev_nonnote_nondebug_insn
+	to check whether insn2 is directly before insn.
+
+* g++.target/i386/pr119689.C: New testcase.
+---
+ gcc/lra-remat.cc                         |  2 +-
+ gcc/testsuite/g++.target/i386/pr119689.C | 44 ++++++++++++++++++++++++
+ 2 files changed, 45 insertions(+), 1 deletion(-)
+ create mode 100644 gcc/testsuite/g++.target/i386/pr119689.C
+
+diff --git a/gcc/lra-remat.cc b/gcc/lra-remat.cc
+index 2f3afffcf5be..5f823193aa73 100644
+--- a/gcc/lra-remat.cc
++++ b/gcc/lra-remat.cc
+@@ -460,7 +460,7 @@ create_cands (void)
+ 		&& dst_regno >= FIRST_PSEUDO_REGISTER
+ 		&& reg_renumber[dst_regno] < 0
+ 		&& BLOCK_FOR_INSN (insn2) == BLOCK_FOR_INSN (insn)
+-		&& insn2 == prev_nonnote_insn (insn))
++		&& insn2 == prev_nonnote_nondebug_insn (insn))
+ 	      {
+ 		create_cand (insn2, regno_potential_cand[src_regno].nop,
+ 			     dst_regno, insn);
+diff --git a/gcc/testsuite/g++.target/i386/pr119689.C b/gcc/testsuite/g++.target/i386/pr119689.C
+new file mode 100644
+index 000000000000..cdc6d2dade53
+--- /dev/null
++++ b/gcc/testsuite/g++.target/i386/pr119689.C
+@@ -0,0 +1,44 @@
++// { dg-do compile }
++// { dg-options "-O2 -fcompare-debug" }
++// { dg-additional-options "-march=i586 -mtune=generic" { target ia32 } }
++// { dg-additional-options "-fPIC" { target { fpic } } }
++
++enum gimple_code { GIMPLE_ASSIGN, GIMPLE_RETURN };
++bool is_gimple_call();
++int m_sig, m_exp, sreal_new_exp;
++struct sreal {
++  sreal(long long sig) {
++    long long __trans_tmp_6 = sig >= 0 ? sig : -(unsigned long long)sig;
++    sig = __trans_tmp_6 <<= sreal_new_exp -= m_exp = __trans_tmp_6;
++    m_sig = sig;
++  }
++  void operator/(sreal);
++};
++struct ipa_predicate {
++  ipa_predicate(bool = true);
++  void operator&=(ipa_predicate);
++  void operator&(ipa_predicate);
++};
++void add_condition();
++gimple_code eliminated_by_inlining_prob_code;
++static int eliminated_by_inlining_prob() {
++  switch (eliminated_by_inlining_prob_code) {
++  case GIMPLE_RETURN:
++    return 2;
++  case GIMPLE_ASSIGN:
++    return 1;
++  }
++  return 0;
++}
++void fp_expression_p() {
++  ipa_predicate bb_predicate;
++  for (;;) {
++    int prob = eliminated_by_inlining_prob();
++    ipa_predicate sra_predicate;
++    sra_predicate &= add_condition;
++    if (is_gimple_call())
++      sreal(prob) / 2;
++    if (prob != 2)
++      bb_predicate & sra_predicate;
++  }
++}
+
+base-commit: 24d1832e0d6edce4f6f717135fcec65d6939e199
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index c3166a6..4e68fca 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -6,6 +6,7 @@
 	- 86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch
 	- 87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch
 	- 88_all_PR119614.patch
+	+ 83_all_PR119689.patch
 
 53	7 April 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-09 13:27 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-09 13:27 UTC (permalink / raw
  To: gentoo-commits
commit:     43881d3525d3af6340ee5f232bd836598470c72e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  9 13:27:22 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr  9 13:27:31 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=43881d35
15.0.0: drop compare-debug patch merged upstream
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/83_all_PR119689.patch | 100 ------------------------------------
 15.0.0/gentoo/README.history        |   1 -
 2 files changed, 101 deletions(-)
diff --git a/15.0.0/gentoo/83_all_PR119689.patch b/15.0.0/gentoo/83_all_PR119689.patch
deleted file mode 100644
index aaa1307..0000000
--- a/15.0.0/gentoo/83_all_PR119689.patch
+++ /dev/null
@@ -1,100 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/20250409124018.R4J_6bGlxGGDb4MRmq3_nKa5BMDlxJ9RZybNrpR3J58@z/
-
-From 83b08e26be60bd1fd03323643f6c75e46b5cc0fd Mon Sep 17 00:00:00 2001
-Message-ID: <83b08e26be60bd1fd03323643f6c75e46b5cc0fd.1744202504.git.sam@gentoo.org>
-From: Richard Biener <rguenther@suse.de>
-Date: Wed, 9 Apr 2025 14:40:18 +0200
-Subject: [PATCH] rtl-optimization/119689 - compare-debug failure with LRA
-
-The previous change to fix LRA rematerialization broke compare-debug
-for i586 bootstrap.  Fixed by using prev_nonnote_nondebug_insn
-instead of prev_nonnote_insn.
-
-Bootstrapped on i586-linux where the miscompare is gone with this
-patch.  Bootstrap and regtest running on x86_64-unknown-linux-gnu.
-
-OK if the latter succeeds?
-
-Thanks,
-Richard.
-
-	PR rtl-optimization/119689
-	PR rtl-optimization/115568
-	* lra-remat.cc (create_cands): Use prev_nonnote_nondebug_insn
-	to check whether insn2 is directly before insn.
-
-* g++.target/i386/pr119689.C: New testcase.
----
- gcc/lra-remat.cc                         |  2 +-
- gcc/testsuite/g++.target/i386/pr119689.C | 44 ++++++++++++++++++++++++
- 2 files changed, 45 insertions(+), 1 deletion(-)
- create mode 100644 gcc/testsuite/g++.target/i386/pr119689.C
-
-diff --git a/gcc/lra-remat.cc b/gcc/lra-remat.cc
-index 2f3afffcf5be..5f823193aa73 100644
---- a/gcc/lra-remat.cc
-+++ b/gcc/lra-remat.cc
-@@ -460,7 +460,7 @@ create_cands (void)
- 		&& dst_regno >= FIRST_PSEUDO_REGISTER
- 		&& reg_renumber[dst_regno] < 0
- 		&& BLOCK_FOR_INSN (insn2) == BLOCK_FOR_INSN (insn)
--		&& insn2 == prev_nonnote_insn (insn))
-+		&& insn2 == prev_nonnote_nondebug_insn (insn))
- 	      {
- 		create_cand (insn2, regno_potential_cand[src_regno].nop,
- 			     dst_regno, insn);
-diff --git a/gcc/testsuite/g++.target/i386/pr119689.C b/gcc/testsuite/g++.target/i386/pr119689.C
-new file mode 100644
-index 000000000000..cdc6d2dade53
---- /dev/null
-+++ b/gcc/testsuite/g++.target/i386/pr119689.C
-@@ -0,0 +1,44 @@
-+// { dg-do compile }
-+// { dg-options "-O2 -fcompare-debug" }
-+// { dg-additional-options "-march=i586 -mtune=generic" { target ia32 } }
-+// { dg-additional-options "-fPIC" { target { fpic } } }
-+
-+enum gimple_code { GIMPLE_ASSIGN, GIMPLE_RETURN };
-+bool is_gimple_call();
-+int m_sig, m_exp, sreal_new_exp;
-+struct sreal {
-+  sreal(long long sig) {
-+    long long __trans_tmp_6 = sig >= 0 ? sig : -(unsigned long long)sig;
-+    sig = __trans_tmp_6 <<= sreal_new_exp -= m_exp = __trans_tmp_6;
-+    m_sig = sig;
-+  }
-+  void operator/(sreal);
-+};
-+struct ipa_predicate {
-+  ipa_predicate(bool = true);
-+  void operator&=(ipa_predicate);
-+  void operator&(ipa_predicate);
-+};
-+void add_condition();
-+gimple_code eliminated_by_inlining_prob_code;
-+static int eliminated_by_inlining_prob() {
-+  switch (eliminated_by_inlining_prob_code) {
-+  case GIMPLE_RETURN:
-+    return 2;
-+  case GIMPLE_ASSIGN:
-+    return 1;
-+  }
-+  return 0;
-+}
-+void fp_expression_p() {
-+  ipa_predicate bb_predicate;
-+  for (;;) {
-+    int prob = eliminated_by_inlining_prob();
-+    ipa_predicate sra_predicate;
-+    sra_predicate &= add_condition;
-+    if (is_gimple_call())
-+      sreal(prob) / 2;
-+    if (prob != 2)
-+      bb_predicate & sra_predicate;
-+  }
-+}
-
-base-commit: 24d1832e0d6edce4f6f717135fcec65d6939e199
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 4e68fca..c3166a6 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -6,7 +6,6 @@
 	- 86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch
 	- 87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch
 	- 88_all_PR119614.patch
-	+ 83_all_PR119689.patch
 
 53	7 April 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-09 15:27 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-09 15:27 UTC (permalink / raw
  To: gentoo-commits
commit:     7ebdc48a0da391f7c167a23940ea301cca35291f
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  9 15:27:04 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr  9 15:27:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=7ebdc48a
15.0.0: add Qt C++23 fix
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/83_all_PR119687.patch | 77 +++++++++++++++++++++++++++++++++++++
 15.0.0/gentoo/README.history        |  1 +
 2 files changed, 78 insertions(+)
diff --git a/15.0.0/gentoo/83_all_PR119687.patch b/15.0.0/gentoo/83_all_PR119687.patch
new file mode 100644
index 0000000..86874fa
--- /dev/null
+++ b/15.0.0/gentoo/83_all_PR119687.patch
@@ -0,0 +1,77 @@
+https://inbox.sourceware.org/gcc-patches/20250409151104.2600656-1-ppalka@redhat.com/
+
+From 660e4bf9391692acb0bb18ba5eb38e689ae0a8a6 Mon Sep 17 00:00:00 2001
+Message-ID: <660e4bf9391692acb0bb18ba5eb38e689ae0a8a6.1744212391.git.sam@gentoo.org>
+From: Patrick Palka <ppalka@redhat.com>
+Date: Wed, 9 Apr 2025 11:11:04 -0400
+Subject: [PATCH] c++: alias_ctad_tweaks ICE w/ inherited CTAD [PR119687]
+
+With inherited CTAD the set of guides may be a two-dimensional overload
+set (i.e. OVERLOADs containing OVERLOADs) so alias_ctad_tweaks (which
+also handles the inherited CTAD transformation) needs to use the 2D-aware
+lkp_iterator instead of ovl_iterator.  Actually, we might as well use
+the more idiomatic lkp_range here.
+
+	PR c++/119687
+
+gcc/cp/ChangeLog:
+
+	* pt.cc (alias_ctad_tweaks): Use lkp_range / lkp_iterator
+	instead of ovl_iterator.
+
+gcc/testsuite/ChangeLog:
+
+* g++.dg/cpp23/class-deduction-inherited8.C: New test.
+---
+ gcc/cp/pt.cc                                  |  3 +--
+ .../g++.dg/cpp23/class-deduction-inherited8.C | 21 +++++++++++++++++++
+ 2 files changed, 22 insertions(+), 2 deletions(-)
+ create mode 100644 gcc/testsuite/g++.dg/cpp23/class-deduction-inherited8.C
+
+diff --git a/gcc/cp/pt.cc b/gcc/cp/pt.cc
+index 0e120c4040ed..352a7f4ed316 100644
+--- a/gcc/cp/pt.cc
++++ b/gcc/cp/pt.cc
+@@ -30937,9 +30937,8 @@ alias_ctad_tweaks (tree tmpl, tree uguides)
+   tree aguides = NULL_TREE;
+   tree atparms = INNERMOST_TEMPLATE_PARMS (fullatparms);
+   unsigned natparms = TREE_VEC_LENGTH (atparms);
+-  for (ovl_iterator iter (uguides); iter; ++iter)
++  for (tree f : lkp_range (uguides))
+     {
+-      tree f = *iter;
+       tree in_decl = f;
+       location_t loc = DECL_SOURCE_LOCATION (f);
+       tree ret = TREE_TYPE (TREE_TYPE (f));
+diff --git a/gcc/testsuite/g++.dg/cpp23/class-deduction-inherited8.C b/gcc/testsuite/g++.dg/cpp23/class-deduction-inherited8.C
+new file mode 100644
+index 000000000000..79fceadd9e1c
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/cpp23/class-deduction-inherited8.C
+@@ -0,0 +1,21 @@
++// PR c++/119687
++// { dg-do compile { target c++20 } }
++
++template <typename> class QFlagsStorage{};
++
++template <typename Enum> struct QFlagsStorageHelper : QFlagsStorage<Enum>  {
++  using QFlagsStorage<Enum>::QFlagsStorage;
++
++public:
++  QFlagsStorageHelper(Enum);
++};
++
++template <typename Enum> struct QFlags : public QFlagsStorageHelper<Enum> {
++  using Base = QFlagsStorageHelper<Enum>;
++  using Base::Base;
++  QFlags(Enum);
++};
++
++void f(int flag) {
++  QFlags{int{}};
++}
+
+base-commit: 334545194d9023fb9b2f72ee0dcde8af94930f25
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index c3166a6..832e5e8 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -6,6 +6,7 @@
 	- 86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch
 	- 87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch
 	- 88_all_PR119614.patch
+	+ 83_all_PR119687.patch
 
 53	7 April 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-10  9:08 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-10  9:08 UTC (permalink / raw
  To: gentoo-commits
commit:     d3eeedf5da5f9bb0af0c6b143e87311033ee39be
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Apr 10 09:07:33 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Apr 10 09:08:15 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=d3eeedf5
15.0.0: support STAGE* GDCFLAGS
Bug: https://gcc.gnu.org/PR116975
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/84_all_PR116975.patch | 320 ++++++++++++++++++++++++++++++++++++
 15.0.0/gentoo/README.history        |   1 +
 2 files changed, 321 insertions(+)
diff --git a/15.0.0/gentoo/84_all_PR116975.patch b/15.0.0/gentoo/84_all_PR116975.patch
new file mode 100644
index 0000000..443cb0f
--- /dev/null
+++ b/15.0.0/gentoo/84_all_PR116975.patch
@@ -0,0 +1,320 @@
+https://inbox.sourceware.org/gcc-patches/20250303221451.131585-1-ibuclaw@gdcproject.org/
+
+From 17de0be9cff1a33289736b3b86cd0428e17aa9aa Mon Sep 17 00:00:00 2001
+Message-ID: <17de0be9cff1a33289736b3b86cd0428e17aa9aa.1744276017.git.sam@gentoo.org>
+From: Iain Buclaw <ibuclaw@gdcproject.org>
+Date: Mon, 3 Mar 2025 23:14:51 +0100
+Subject: [PATCH] Makefile.tpl: Implement per-stage GDCFLAGS [PR116975]
+
+Hi,
+
+This patch implements STAGE1_GDCFLAGS and others to the configure
+machinery, allowing the GDCFLAGS for each bootstrap stage of building
+gdc to be overriden, as is the case with CXXFLAGS for other front-ends.
+
+This is limited to just the generation of recipes for the
+configure-stage-gcc and all-stage-gcc, as a D compiler is not optionally
+needed by any other module.
+
+OK for mainline?
+
+Regards,
+Iain.
+---
+ Makefile.in  | 51 +++++++++++++++++++++++++++++++++++++++++++++++++++
+ Makefile.tpl | 15 +++++++++++++--
+ 2 files changed, 64 insertions(+), 2 deletions(-)
+
+diff --git a/Makefile.in b/Makefile.in
+index b1ed67d3d4f1..202a504e565f 100644
+--- a/Makefile.in
++++ b/Makefile.in
+@@ -620,6 +620,26 @@ STAGE1_CONFIGURE_FLAGS = $(STAGE1_CHECKING) \
+ 	  --disable-build-format-warnings
+ 
+ @if target-libphobos-bootstrap
++# Defaults for each stage if we're bootstrapping D.
++
++STAGE1_GDCFLAGS = $(GDCFLAGS)
++
++STAGE2_GDCFLAGS = $(GDCFLAGS)
++
++STAGE3_GDCFLAGS = $(GDCFLAGS)
++
++STAGE4_GDCFLAGS = $(GDCFLAGS)
++
++STAGEprofile_GDCFLAGS = $(GDCFLAGS)
++
++STAGEtrain_GDCFLAGS = $(GDCFLAGS)
++
++STAGEfeedback_GDCFLAGS = $(GDCFLAGS)
++
++STAGEautoprofile_GDCFLAGS = $(GDCFLAGS)
++
++STAGEautofeedback_GDCFLAGS = $(GDCFLAGS)
++
+ STAGE1_CONFIGURE_FLAGS += --with-libphobos-druntime-only
+ STAGE2_CONFIGURE_FLAGS += --with-libphobos-druntime-only
+ @endif target-libphobos-bootstrap
+@@ -633,6 +653,10 @@ STAGE2_CFLAGS += -fno-checking
+ STAGE2_TFLAGS += -fno-checking
+ STAGE3_CFLAGS += -fchecking=1
+ STAGE3_TFLAGS += -fchecking=1
++@if target-libphobos-bootstrap
++STAGE2_GDCFLAGS += -fno-checking
++STAGE3_GDCFLAGS += -fchecking=1
++@endif target-libphobos-bootstrap
+ 
+ STAGEprofile_CFLAGS = $(STAGE2_CFLAGS) -fprofile-generate
+ STAGEprofile_TFLAGS = $(STAGE2_TFLAGS)
+@@ -922,38 +946,47 @@ BASE_FLAGS_TO_PASS = \
+ 	"LEAN=$(LEAN)" \
+ 	"STAGE1_CFLAGS=$(STAGE1_CFLAGS)" \
+ 	"STAGE1_CXXFLAGS=$(STAGE1_CXXFLAGS)" \
++	"STAGE1_GDCFLAGS=$(STAGE1_GDCFLAGS)" \
+ 	"STAGE1_GENERATOR_CFLAGS=$(STAGE1_GENERATOR_CFLAGS)" \
+ 	"STAGE1_TFLAGS=$(STAGE1_TFLAGS)" \
+ 	"STAGE2_CFLAGS=$(STAGE2_CFLAGS)" \
+ 	"STAGE2_CXXFLAGS=$(STAGE2_CXXFLAGS)" \
++	"STAGE2_GDCFLAGS=$(STAGE2_GDCFLAGS)" \
+ 	"STAGE2_GENERATOR_CFLAGS=$(STAGE2_GENERATOR_CFLAGS)" \
+ 	"STAGE2_TFLAGS=$(STAGE2_TFLAGS)" \
+ 	"STAGE3_CFLAGS=$(STAGE3_CFLAGS)" \
+ 	"STAGE3_CXXFLAGS=$(STAGE3_CXXFLAGS)" \
++	"STAGE3_GDCFLAGS=$(STAGE3_GDCFLAGS)" \
+ 	"STAGE3_GENERATOR_CFLAGS=$(STAGE3_GENERATOR_CFLAGS)" \
+ 	"STAGE3_TFLAGS=$(STAGE3_TFLAGS)" \
+ 	"STAGE4_CFLAGS=$(STAGE4_CFLAGS)" \
+ 	"STAGE4_CXXFLAGS=$(STAGE4_CXXFLAGS)" \
++	"STAGE4_GDCFLAGS=$(STAGE4_GDCFLAGS)" \
+ 	"STAGE4_GENERATOR_CFLAGS=$(STAGE4_GENERATOR_CFLAGS)" \
+ 	"STAGE4_TFLAGS=$(STAGE4_TFLAGS)" \
+ 	"STAGEprofile_CFLAGS=$(STAGEprofile_CFLAGS)" \
+ 	"STAGEprofile_CXXFLAGS=$(STAGEprofile_CXXFLAGS)" \
++	"STAGEprofile_GDCFLAGS=$(STAGEprofile_GDCFLAGS)" \
+ 	"STAGEprofile_GENERATOR_CFLAGS=$(STAGEprofile_GENERATOR_CFLAGS)" \
+ 	"STAGEprofile_TFLAGS=$(STAGEprofile_TFLAGS)" \
+ 	"STAGEtrain_CFLAGS=$(STAGEtrain_CFLAGS)" \
+ 	"STAGEtrain_CXXFLAGS=$(STAGEtrain_CXXFLAGS)" \
++	"STAGEtrain_GDCFLAGS=$(STAGEtrain_GDCFLAGS)" \
+ 	"STAGEtrain_GENERATOR_CFLAGS=$(STAGEtrain_GENERATOR_CFLAGS)" \
+ 	"STAGEtrain_TFLAGS=$(STAGEtrain_TFLAGS)" \
+ 	"STAGEfeedback_CFLAGS=$(STAGEfeedback_CFLAGS)" \
+ 	"STAGEfeedback_CXXFLAGS=$(STAGEfeedback_CXXFLAGS)" \
++	"STAGEfeedback_GDCFLAGS=$(STAGEfeedback_GDCFLAGS)" \
+ 	"STAGEfeedback_GENERATOR_CFLAGS=$(STAGEfeedback_GENERATOR_CFLAGS)" \
+ 	"STAGEfeedback_TFLAGS=$(STAGEfeedback_TFLAGS)" \
+ 	"STAGEautoprofile_CFLAGS=$(STAGEautoprofile_CFLAGS)" \
+ 	"STAGEautoprofile_CXXFLAGS=$(STAGEautoprofile_CXXFLAGS)" \
++	"STAGEautoprofile_GDCFLAGS=$(STAGEautoprofile_GDCFLAGS)" \
+ 	"STAGEautoprofile_GENERATOR_CFLAGS=$(STAGEautoprofile_GENERATOR_CFLAGS)" \
+ 	"STAGEautoprofile_TFLAGS=$(STAGEautoprofile_TFLAGS)" \
+ 	"STAGEautofeedback_CFLAGS=$(STAGEautofeedback_CFLAGS)" \
+ 	"STAGEautofeedback_CXXFLAGS=$(STAGEautofeedback_CXXFLAGS)" \
++	"STAGEautofeedback_GDCFLAGS=$(STAGEautofeedback_GDCFLAGS)" \
+ 	"STAGEautofeedback_GENERATOR_CFLAGS=$(STAGEautofeedback_GENERATOR_CFLAGS)" \
+ 	"STAGEautofeedback_TFLAGS=$(STAGEautofeedback_TFLAGS)" \
+ 	$(CXX_FOR_TARGET_FLAG_TO_PASS) \
+@@ -12134,6 +12167,7 @@ configure-stage1-gcc:
+ 	$(HOST_EXPORTS) \
+ 	CFLAGS="$(STAGE1_CFLAGS)"; export CFLAGS; \
+ 	CXXFLAGS="$(STAGE1_CXXFLAGS)"; export CXXFLAGS; \
++	GDCFLAGS="$(STAGE1_GDCFLAGS)"; export GDCFLAGS; \
+ 	LIBCFLAGS="$(LIBCFLAGS)"; export LIBCFLAGS;  \
+ 	echo Configuring stage 1 in $(HOST_SUBDIR)/gcc; \
+ 	$(SHELL) $(srcdir)/mkinstalldirs $(HOST_SUBDIR)/gcc; \
+@@ -12168,6 +12202,7 @@ configure-stage2-gcc:
+ 	$(POSTSTAGE1_HOST_EXPORTS) \
+ 	CFLAGS="$(STAGE2_CFLAGS)"; export CFLAGS; \
+ 	CXXFLAGS="$(STAGE2_CXXFLAGS)"; export CXXFLAGS; \
++	GDCFLAGS="$(STAGE2_GDCFLAGS)"; export GDCFLAGS; \
+ 	LIBCFLAGS="$(STAGE2_CFLAGS)"; export LIBCFLAGS;  \
+ 	echo Configuring stage 2 in $(HOST_SUBDIR)/gcc; \
+ 	$(SHELL) $(srcdir)/mkinstalldirs $(HOST_SUBDIR)/gcc; \
+@@ -12202,6 +12237,7 @@ configure-stage3-gcc:
+ 	$(POSTSTAGE1_HOST_EXPORTS) \
+ 	CFLAGS="$(STAGE3_CFLAGS)"; export CFLAGS; \
+ 	CXXFLAGS="$(STAGE3_CXXFLAGS)"; export CXXFLAGS; \
++	GDCFLAGS="$(STAGE3_GDCFLAGS)"; export GDCFLAGS; \
+ 	LIBCFLAGS="$(STAGE3_CFLAGS)"; export LIBCFLAGS;  \
+ 	echo Configuring stage 3 in $(HOST_SUBDIR)/gcc; \
+ 	$(SHELL) $(srcdir)/mkinstalldirs $(HOST_SUBDIR)/gcc; \
+@@ -12236,6 +12272,7 @@ configure-stage4-gcc:
+ 	$(POSTSTAGE1_HOST_EXPORTS) \
+ 	CFLAGS="$(STAGE4_CFLAGS)"; export CFLAGS; \
+ 	CXXFLAGS="$(STAGE4_CXXFLAGS)"; export CXXFLAGS; \
++	GDCFLAGS="$(STAGE4_GDCFLAGS)"; export GDCFLAGS; \
+ 	LIBCFLAGS="$(STAGE4_CFLAGS)"; export LIBCFLAGS;  \
+ 	echo Configuring stage 4 in $(HOST_SUBDIR)/gcc; \
+ 	$(SHELL) $(srcdir)/mkinstalldirs $(HOST_SUBDIR)/gcc; \
+@@ -12270,6 +12307,7 @@ configure-stageprofile-gcc:
+ 	$(POSTSTAGE1_HOST_EXPORTS) \
+ 	CFLAGS="$(STAGEprofile_CFLAGS)"; export CFLAGS; \
+ 	CXXFLAGS="$(STAGEprofile_CXXFLAGS)"; export CXXFLAGS; \
++	GDCFLAGS="$(STAGEprofile_GDCFLAGS)"; export GDCFLAGS; \
+ 	LIBCFLAGS="$(STAGEprofile_CFLAGS)"; export LIBCFLAGS;  \
+ 	echo Configuring stage profile in $(HOST_SUBDIR)/gcc; \
+ 	$(SHELL) $(srcdir)/mkinstalldirs $(HOST_SUBDIR)/gcc; \
+@@ -12304,6 +12342,7 @@ configure-stagetrain-gcc:
+ 	$(POSTSTAGE1_HOST_EXPORTS) \
+ 	CFLAGS="$(STAGEtrain_CFLAGS)"; export CFLAGS; \
+ 	CXXFLAGS="$(STAGEtrain_CXXFLAGS)"; export CXXFLAGS; \
++	GDCFLAGS="$(STAGEtrain_GDCFLAGS)"; export GDCFLAGS; \
+ 	LIBCFLAGS="$(STAGEtrain_CFLAGS)"; export LIBCFLAGS;  \
+ 	echo Configuring stage train in $(HOST_SUBDIR)/gcc; \
+ 	$(SHELL) $(srcdir)/mkinstalldirs $(HOST_SUBDIR)/gcc; \
+@@ -12338,6 +12377,7 @@ configure-stagefeedback-gcc:
+ 	$(POSTSTAGE1_HOST_EXPORTS) \
+ 	CFLAGS="$(STAGEfeedback_CFLAGS)"; export CFLAGS; \
+ 	CXXFLAGS="$(STAGEfeedback_CXXFLAGS)"; export CXXFLAGS; \
++	GDCFLAGS="$(STAGEfeedback_GDCFLAGS)"; export GDCFLAGS; \
+ 	LIBCFLAGS="$(STAGEfeedback_CFLAGS)"; export LIBCFLAGS;  \
+ 	echo Configuring stage feedback in $(HOST_SUBDIR)/gcc; \
+ 	$(SHELL) $(srcdir)/mkinstalldirs $(HOST_SUBDIR)/gcc; \
+@@ -12372,6 +12412,7 @@ configure-stageautoprofile-gcc:
+ 	$(POSTSTAGE1_HOST_EXPORTS) \
+ 	CFLAGS="$(STAGEautoprofile_CFLAGS)"; export CFLAGS; \
+ 	CXXFLAGS="$(STAGEautoprofile_CXXFLAGS)"; export CXXFLAGS; \
++	GDCFLAGS="$(STAGEautoprofile_GDCFLAGS)"; export GDCFLAGS; \
+ 	LIBCFLAGS="$(STAGEautoprofile_CFLAGS)"; export LIBCFLAGS;  \
+ 	echo Configuring stage autoprofile in $(HOST_SUBDIR)/gcc; \
+ 	$(SHELL) $(srcdir)/mkinstalldirs $(HOST_SUBDIR)/gcc; \
+@@ -12406,6 +12447,7 @@ configure-stageautofeedback-gcc:
+ 	$(POSTSTAGE1_HOST_EXPORTS) \
+ 	CFLAGS="$(STAGEautofeedback_CFLAGS)"; export CFLAGS; \
+ 	CXXFLAGS="$(STAGEautofeedback_CXXFLAGS)"; export CXXFLAGS; \
++	GDCFLAGS="$(STAGEautofeedback_GDCFLAGS)"; export GDCFLAGS; \
+ 	LIBCFLAGS="$(STAGEautofeedback_CFLAGS)"; export LIBCFLAGS;  \
+ 	echo Configuring stage autofeedback in $(HOST_SUBDIR)/gcc; \
+ 	$(SHELL) $(srcdir)/mkinstalldirs $(HOST_SUBDIR)/gcc; \
+@@ -12468,6 +12510,7 @@ all-stage1-gcc: configure-stage1-gcc
+ 		CFLAGS="$(STAGE1_CFLAGS)" \
+ 		GENERATOR_CFLAGS="$(STAGE1_GENERATOR_CFLAGS)" \
+ 		CXXFLAGS="$(STAGE1_CXXFLAGS)" \
++		GDCFLAGS="$(STAGE1_GDCFLAGS)" \
+ 		LIBCFLAGS="$(LIBCFLAGS)" \
+ 		CFLAGS_FOR_TARGET="$(CFLAGS_FOR_TARGET)" \
+ 		CXXFLAGS_FOR_TARGET="$(CXXFLAGS_FOR_TARGET)" \
+@@ -12513,6 +12556,7 @@ all-stage2-gcc: configure-stage2-gcc
+ 		CFLAGS="$(STAGE2_CFLAGS)" \
+ 		GENERATOR_CFLAGS="$(STAGE2_GENERATOR_CFLAGS)" \
+ 		CXXFLAGS="$(STAGE2_CXXFLAGS)" \
++		GDCFLAGS="$(STAGE2_GDCFLAGS)" \
+ 		LIBCFLAGS="$(STAGE2_CFLAGS)" \
+ 		CFLAGS_FOR_TARGET="$(CFLAGS_FOR_TARGET)" \
+ 		CXXFLAGS_FOR_TARGET="$(CXXFLAGS_FOR_TARGET)" \
+@@ -12556,6 +12600,7 @@ all-stage3-gcc: configure-stage3-gcc
+ 		CFLAGS="$(STAGE3_CFLAGS)" \
+ 		GENERATOR_CFLAGS="$(STAGE3_GENERATOR_CFLAGS)" \
+ 		CXXFLAGS="$(STAGE3_CXXFLAGS)" \
++		GDCFLAGS="$(STAGE3_GDCFLAGS)" \
+ 		LIBCFLAGS="$(STAGE3_CFLAGS)" \
+ 		CFLAGS_FOR_TARGET="$(CFLAGS_FOR_TARGET)" \
+ 		CXXFLAGS_FOR_TARGET="$(CXXFLAGS_FOR_TARGET)" \
+@@ -12599,6 +12644,7 @@ all-stage4-gcc: configure-stage4-gcc
+ 		CFLAGS="$(STAGE4_CFLAGS)" \
+ 		GENERATOR_CFLAGS="$(STAGE4_GENERATOR_CFLAGS)" \
+ 		CXXFLAGS="$(STAGE4_CXXFLAGS)" \
++		GDCFLAGS="$(STAGE4_GDCFLAGS)" \
+ 		LIBCFLAGS="$(STAGE4_CFLAGS)" \
+ 		CFLAGS_FOR_TARGET="$(CFLAGS_FOR_TARGET)" \
+ 		CXXFLAGS_FOR_TARGET="$(CXXFLAGS_FOR_TARGET)" \
+@@ -12642,6 +12688,7 @@ all-stageprofile-gcc: configure-stageprofile-gcc
+ 		CFLAGS="$(STAGEprofile_CFLAGS)" \
+ 		GENERATOR_CFLAGS="$(STAGEprofile_GENERATOR_CFLAGS)" \
+ 		CXXFLAGS="$(STAGEprofile_CXXFLAGS)" \
++		GDCFLAGS="$(STAGEprofile_GDCFLAGS)" \
+ 		LIBCFLAGS="$(STAGEprofile_CFLAGS)" \
+ 		CFLAGS_FOR_TARGET="$(CFLAGS_FOR_TARGET)" \
+ 		CXXFLAGS_FOR_TARGET="$(CXXFLAGS_FOR_TARGET)" \
+@@ -12685,6 +12732,7 @@ all-stagetrain-gcc: configure-stagetrain-gcc
+ 		CFLAGS="$(STAGEtrain_CFLAGS)" \
+ 		GENERATOR_CFLAGS="$(STAGEtrain_GENERATOR_CFLAGS)" \
+ 		CXXFLAGS="$(STAGEtrain_CXXFLAGS)" \
++		GDCFLAGS="$(STAGEtrain_GDCFLAGS)" \
+ 		LIBCFLAGS="$(STAGEtrain_CFLAGS)" \
+ 		CFLAGS_FOR_TARGET="$(CFLAGS_FOR_TARGET)" \
+ 		CXXFLAGS_FOR_TARGET="$(CXXFLAGS_FOR_TARGET)" \
+@@ -12728,6 +12776,7 @@ all-stagefeedback-gcc: configure-stagefeedback-gcc
+ 		CFLAGS="$(STAGEfeedback_CFLAGS)" \
+ 		GENERATOR_CFLAGS="$(STAGEfeedback_GENERATOR_CFLAGS)" \
+ 		CXXFLAGS="$(STAGEfeedback_CXXFLAGS)" \
++		GDCFLAGS="$(STAGEfeedback_GDCFLAGS)" \
+ 		LIBCFLAGS="$(STAGEfeedback_CFLAGS)" \
+ 		CFLAGS_FOR_TARGET="$(CFLAGS_FOR_TARGET)" \
+ 		CXXFLAGS_FOR_TARGET="$(CXXFLAGS_FOR_TARGET)" \
+@@ -12771,6 +12820,7 @@ all-stageautoprofile-gcc: configure-stageautoprofile-gcc
+ 		CFLAGS="$(STAGEautoprofile_CFLAGS)" \
+ 		GENERATOR_CFLAGS="$(STAGEautoprofile_GENERATOR_CFLAGS)" \
+ 		CXXFLAGS="$(STAGEautoprofile_CXXFLAGS)" \
++		GDCFLAGS="$(STAGEautoprofile_GDCFLAGS)" \
+ 		LIBCFLAGS="$(STAGEautoprofile_CFLAGS)" \
+ 		CFLAGS_FOR_TARGET="$(CFLAGS_FOR_TARGET)" \
+ 		CXXFLAGS_FOR_TARGET="$(CXXFLAGS_FOR_TARGET)" \
+@@ -12814,6 +12864,7 @@ all-stageautofeedback-gcc: configure-stageautofeedback-gcc
+ 		CFLAGS="$(STAGEautofeedback_CFLAGS)" \
+ 		GENERATOR_CFLAGS="$(STAGEautofeedback_GENERATOR_CFLAGS)" \
+ 		CXXFLAGS="$(STAGEautofeedback_CXXFLAGS)" \
++		GDCFLAGS="$(STAGEautofeedback_GDCFLAGS)" \
+ 		LIBCFLAGS="$(STAGEautofeedback_CFLAGS)" \
+ 		CFLAGS_FOR_TARGET="$(CFLAGS_FOR_TARGET)" \
+ 		CXXFLAGS_FOR_TARGET="$(CXXFLAGS_FOR_TARGET)" \
+diff --git a/Makefile.tpl b/Makefile.tpl
+index 7dccf91ed8ec..15b99ef31eed 100644
+--- a/Makefile.tpl
++++ b/Makefile.tpl
+@@ -543,6 +543,10 @@ STAGE1_CONFIGURE_FLAGS = $(STAGE1_CHECKING) \
+ 	  --disable-build-format-warnings
+ 
+ @if target-libphobos-bootstrap
++# Defaults for each stage if we're bootstrapping D.
++[+ FOR bootstrap-stage +]
++STAGE[+id+]_GDCFLAGS = $(GDCFLAGS)
++[+ ENDFOR bootstrap-stage +]
+ STAGE1_CONFIGURE_FLAGS += --with-libphobos-druntime-only
+ STAGE2_CONFIGURE_FLAGS += --with-libphobos-druntime-only
+ @endif target-libphobos-bootstrap
+@@ -556,6 +560,10 @@ STAGE2_CFLAGS += -fno-checking
+ STAGE2_TFLAGS += -fno-checking
+ STAGE3_CFLAGS += -fchecking=1
+ STAGE3_TFLAGS += -fchecking=1
++@if target-libphobos-bootstrap
++STAGE2_GDCFLAGS += -fno-checking
++STAGE3_GDCFLAGS += -fchecking=1
++@endif target-libphobos-bootstrap
+ 
+ STAGEprofile_CFLAGS = $(STAGE2_CFLAGS) -fprofile-generate
+ STAGEprofile_TFLAGS = $(STAGE2_TFLAGS)
+@@ -710,6 +718,7 @@ BASE_FLAGS_TO_PASS =[+ FOR flags_to_pass +][+ IF optional +] \
+ 	"[+flag+]=$([+flag+])"[+ ENDIF optional+][+ ENDFOR flags_to_pass +][+ FOR bootstrap-stage +] \
+ 	"STAGE[+id+]_CFLAGS=$(STAGE[+id+]_CFLAGS)" \
+ 	"STAGE[+id+]_CXXFLAGS=$(STAGE[+id+]_CXXFLAGS)" \
++	"STAGE[+id+]_GDCFLAGS=$(STAGE[+id+]_GDCFLAGS)" \
+ 	"STAGE[+id+]_GENERATOR_CFLAGS=$(STAGE[+id+]_GENERATOR_CFLAGS)" \
+ 	"STAGE[+id+]_TFLAGS=$(STAGE[+id+]_TFLAGS)"[+ ENDFOR bootstrap-stage +] \
+ 	$(CXX_FOR_TARGET_FLAG_TO_PASS) \
+@@ -1237,7 +1246,8 @@ configure-stage[+id+]-[+prefix+][+module+]:
+ 	CXXFLAGS="$(CXXFLAGS_FOR_TARGET)"; export CXXFLAGS; \
+ 	LIBCFLAGS="$(LIBCFLAGS_FOR_TARGET)"; export LIBCFLAGS;[+ ELSE prefix +] \
+ 	CFLAGS="$(STAGE[+id+]_CFLAGS)"; export CFLAGS; \
+-	CXXFLAGS="$(STAGE[+id+]_CXXFLAGS)"; export CXXFLAGS;[+ IF prev +] \
++	CXXFLAGS="$(STAGE[+id+]_CXXFLAGS)"; export CXXFLAGS;[+ IF (= (get "module") "gcc") +] \
++	GDCFLAGS="$(STAGE[+id+]_GDCFLAGS)"; export GDCFLAGS;[+ ENDIF +][+ IF prev +] \
+ 	LIBCFLAGS="$(STAGE[+id+]_CFLAGS)"[+ ELSE prev +] \
+ 	LIBCFLAGS="$(LIBCFLAGS)"[+ ENDIF prev +]; export LIBCFLAGS;[+
+   ENDIF prefix +] [+extra_exports+] \
+@@ -1307,7 +1317,8 @@ all-stage[+id+]-[+prefix+][+module+]: configure-stage[+id+]-[+prefix+][+module+]
+ 		LIBCFLAGS="$(LIBCFLAGS_FOR_TARGET)"[+ ELSE prefix +] \
+ 		CFLAGS="$(STAGE[+id+]_CFLAGS)" \
+ 		GENERATOR_CFLAGS="$(STAGE[+id+]_GENERATOR_CFLAGS)" \
+-		CXXFLAGS="$(STAGE[+id+]_CXXFLAGS)"[+ IF prev +] \
++		CXXFLAGS="$(STAGE[+id+]_CXXFLAGS)"[+ IF (= (get "module") "gcc") +] \
++		GDCFLAGS="$(STAGE[+id+]_GDCFLAGS)"[+ ENDIF +][+ IF prev +] \
+ 		LIBCFLAGS="$(STAGE[+id+]_CFLAGS)"[+ ELSE prev +] \
+ 		LIBCFLAGS="$(LIBCFLAGS)"[+ ENDIF prev +][+ ENDIF prefix +] \
+ 		CFLAGS_FOR_TARGET="$(CFLAGS_FOR_TARGET)" \
+
+base-commit: 72dff34bcdd6f05b64bbf07739ab815e673b5946
+-- 
+2.49.0
+
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 832e5e8..190b29b 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -7,6 +7,7 @@
 	- 87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch
 	- 88_all_PR119614.patch
 	+ 83_all_PR119687.patch
+	+ 84_all_PR116975.patch
 
 53	7 April 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-10 21:59 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-10 21:59 UTC (permalink / raw
  To: gentoo-commits
commit:     b83b3cd6a079211515a891c3c8bfd008a197f1d6
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Apr 10 21:59:22 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Apr 10 21:59:22 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=b83b3cd6
15.0.0: drop C++/qt patch merged upstream
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/83_all_PR119687.patch | 77 -------------------------------------
 15.0.0/gentoo/README.history        |  1 -
 2 files changed, 78 deletions(-)
diff --git a/15.0.0/gentoo/83_all_PR119687.patch b/15.0.0/gentoo/83_all_PR119687.patch
deleted file mode 100644
index 86874fa..0000000
--- a/15.0.0/gentoo/83_all_PR119687.patch
+++ /dev/null
@@ -1,77 +0,0 @@
-https://inbox.sourceware.org/gcc-patches/20250409151104.2600656-1-ppalka@redhat.com/
-
-From 660e4bf9391692acb0bb18ba5eb38e689ae0a8a6 Mon Sep 17 00:00:00 2001
-Message-ID: <660e4bf9391692acb0bb18ba5eb38e689ae0a8a6.1744212391.git.sam@gentoo.org>
-From: Patrick Palka <ppalka@redhat.com>
-Date: Wed, 9 Apr 2025 11:11:04 -0400
-Subject: [PATCH] c++: alias_ctad_tweaks ICE w/ inherited CTAD [PR119687]
-
-With inherited CTAD the set of guides may be a two-dimensional overload
-set (i.e. OVERLOADs containing OVERLOADs) so alias_ctad_tweaks (which
-also handles the inherited CTAD transformation) needs to use the 2D-aware
-lkp_iterator instead of ovl_iterator.  Actually, we might as well use
-the more idiomatic lkp_range here.
-
-	PR c++/119687
-
-gcc/cp/ChangeLog:
-
-	* pt.cc (alias_ctad_tweaks): Use lkp_range / lkp_iterator
-	instead of ovl_iterator.
-
-gcc/testsuite/ChangeLog:
-
-* g++.dg/cpp23/class-deduction-inherited8.C: New test.
----
- gcc/cp/pt.cc                                  |  3 +--
- .../g++.dg/cpp23/class-deduction-inherited8.C | 21 +++++++++++++++++++
- 2 files changed, 22 insertions(+), 2 deletions(-)
- create mode 100644 gcc/testsuite/g++.dg/cpp23/class-deduction-inherited8.C
-
-diff --git a/gcc/cp/pt.cc b/gcc/cp/pt.cc
-index 0e120c4040ed..352a7f4ed316 100644
---- a/gcc/cp/pt.cc
-+++ b/gcc/cp/pt.cc
-@@ -30937,9 +30937,8 @@ alias_ctad_tweaks (tree tmpl, tree uguides)
-   tree aguides = NULL_TREE;
-   tree atparms = INNERMOST_TEMPLATE_PARMS (fullatparms);
-   unsigned natparms = TREE_VEC_LENGTH (atparms);
--  for (ovl_iterator iter (uguides); iter; ++iter)
-+  for (tree f : lkp_range (uguides))
-     {
--      tree f = *iter;
-       tree in_decl = f;
-       location_t loc = DECL_SOURCE_LOCATION (f);
-       tree ret = TREE_TYPE (TREE_TYPE (f));
-diff --git a/gcc/testsuite/g++.dg/cpp23/class-deduction-inherited8.C b/gcc/testsuite/g++.dg/cpp23/class-deduction-inherited8.C
-new file mode 100644
-index 000000000000..79fceadd9e1c
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/cpp23/class-deduction-inherited8.C
-@@ -0,0 +1,21 @@
-+// PR c++/119687
-+// { dg-do compile { target c++20 } }
-+
-+template <typename> class QFlagsStorage{};
-+
-+template <typename Enum> struct QFlagsStorageHelper : QFlagsStorage<Enum>  {
-+  using QFlagsStorage<Enum>::QFlagsStorage;
-+
-+public:
-+  QFlagsStorageHelper(Enum);
-+};
-+
-+template <typename Enum> struct QFlags : public QFlagsStorageHelper<Enum> {
-+  using Base = QFlagsStorageHelper<Enum>;
-+  using Base::Base;
-+  QFlags(Enum);
-+};
-+
-+void f(int flag) {
-+  QFlags{int{}};
-+}
-
-base-commit: 334545194d9023fb9b2f72ee0dcde8af94930f25
--- 
-2.49.0
-
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 190b29b..f0db01f 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -6,7 +6,6 @@
 	- 86_all_combine-Limit-insn-searchs-for-2-2-combinations-PR11.patch
 	- 87_all_simplify-rtx-Fix-shortcut-for-vector-eq-ne.patch
 	- 88_all_PR119614.patch
-	+ 83_all_PR119687.patch
 	+ 84_all_PR116975.patch
 
 53	7 April 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-13 22:54 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-13 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     8cd53652a77e14ecca976fee2a7b44878dc30c7e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 13 22:54:24 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Apr 13 22:54:24 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=8cd53652
15.0.0: cut patchset 54
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index f0db01f..dfcf34b 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-54	????
+54	13 April 2025
 
 	- 83_all_combine-Allow-2-2-combinations-but-with-a-tweak-PR11.patch
 	- 84_all_combine-Avoid-split_i2i3-search-if-i2-is-unchanged-P.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-14 16:08 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-14 16:08 UTC (permalink / raw
  To: gentoo-commits
commit:     374541e4b474fc83440a3c192a6bf07a9dc07bbd
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 14 16:08:31 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Apr 14 16:08:31 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=374541e4
15.0.0: rename GDCFLAGS patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../gentoo/{84_all_PR116975.patch => 84_all_PR116975-GDCFLAGS.patch} | 0
 15.0.0/gentoo/README.history                                         | 5 +++++
 2 files changed, 5 insertions(+)
diff --git a/15.0.0/gentoo/84_all_PR116975.patch b/15.0.0/gentoo/84_all_PR116975-GDCFLAGS.patch
similarity index 100%
rename from 15.0.0/gentoo/84_all_PR116975.patch
rename to 15.0.0/gentoo/84_all_PR116975-GDCFLAGS.patch
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index dfcf34b..f2463fa 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,3 +1,8 @@
+55	????
+
+	- 84_all_PR116975.patch
+	+ 84_all_PR116975-GDCFLAGS.patch
+
 54	13 April 2025
 
 	- 83_all_combine-Allow-2-2-combinations-but-with-a-tweak-PR11.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-14 16:08 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-14 16:08 UTC (permalink / raw
  To: gentoo-commits
commit:     1448bc2c4a374ac990c89edb470b0b56c8d7e502
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 14 16:08:46 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Apr 14 16:08:46 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=1448bc2c
15.0.0: drop ipa-cp patch merged upstream
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/82_all_PR119318-ipa-cp.patch | 168 -----------------------------
 15.0.0/gentoo/README.history               |   1 +
 2 files changed, 1 insertion(+), 168 deletions(-)
diff --git a/15.0.0/gentoo/82_all_PR119318-ipa-cp.patch b/15.0.0/gentoo/82_all_PR119318-ipa-cp.patch
deleted file mode 100644
index 895e25e..0000000
--- a/15.0.0/gentoo/82_all_PR119318-ipa-cp.patch
+++ /dev/null
@@ -1,168 +0,0 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119318#c5
-
-Subject: [PATCH] ipa-cp: Make propagation of bits in IPA-CP aware of type conversions (PR119318)
-
-After the propagation of constants and value ranges, it turns out
-that the propagation of known bits also needs to be made aware of any
-intermediate types in which any arithmetic operations are made and
-must limit its precision there.  This implements just that.
-
-Bootstrapped and tested on x86_64-linux.
-
-gcc/ChangeLog:
-
-2025-03-18  Martin Jambor  <mjambor@suse.cz>
-
-	PR ipa/119318
-	* ipa-cp.cc (ipcp_bits_lattice::meet_with_1): Set all mask bits
-	not covered by precision to one.
-	(ipcp_bits_lattice::meet_with): Likewise.
-	(propagate_bits_across_jump_function): Use the first operand type
-	rather than the final parameter one to perform meet with other
-	lattices.  Check the operation conforms with
-	expr_type_first_operand_type_p.
-	* tree.cc (expr_type_first_operand_type_p): Add POINTER_PLUS_EXPR.
-
-gcc/testsuite/ChangeLog:
-
-2025-03-18  Martin Jambor  <mjambor@suse.cz>
-
-	PR ipa/119318
-	* gcc.dg/ipa/pr119318.c: New test.
----
- gcc/ipa-cp.cc                       | 26 +++++++++++++++++---
- gcc/testsuite/gcc.dg/ipa/pr119318.c | 38 +++++++++++++++++++++++++++++
- gcc/tree.cc                         |  1 +
- 3 files changed, 61 insertions(+), 4 deletions(-)
- create mode 100644 gcc/testsuite/gcc.dg/ipa/pr119318.c
-
-diff --git a/gcc/ipa-cp.cc b/gcc/ipa-cp.cc
-index 264568989a9..eff20a9ac55 100644
---- a/gcc/ipa-cp.cc
-+++ b/gcc/ipa-cp.cc
-@@ -918,6 +918,8 @@ ipcp_bits_lattice::meet_with_1 (widest_int value, widest_int mask,
-     m_mask |= m_value;
-   m_value &= ~m_mask;
- 
-+  widest_int cap_mask = wi::bit_not (wi::sub (wi::lshift (1, precision), 1));
-+  m_mask |= cap_mask;
-   if (wi::sext (m_mask, precision) == -1)
-     return set_to_bottom ();
- 
-@@ -996,6 +998,8 @@ ipcp_bits_lattice::meet_with (ipcp_bits_lattice& other, unsigned precision,
- 	  adjusted_mask |= adjusted_value;
- 	  adjusted_value &= ~adjusted_mask;
- 	}
-+      widest_int cap_mask = wi::bit_not (wi::sub (wi::lshift (1, precision), 1));
-+      adjusted_mask |= cap_mask;
-       if (wi::sext (adjusted_mask, precision) == -1)
- 	return set_to_bottom ();
-       return set_to_constant (adjusted_value, adjusted_mask);
-@@ -2507,9 +2511,6 @@ propagate_bits_across_jump_function (cgraph_edge *cs, int idx,
-       return dest_lattice->set_to_bottom ();
-     }
- 
--  unsigned precision = TYPE_PRECISION (parm_type);
--  signop sgn = TYPE_SIGN (parm_type);
--
-   if (jfunc->type == IPA_JF_PASS_THROUGH
-       || jfunc->type == IPA_JF_ANCESTOR)
-     {
-@@ -2522,6 +2523,16 @@ propagate_bits_across_jump_function (cgraph_edge *cs, int idx,
-       if (jfunc->type == IPA_JF_PASS_THROUGH)
- 	{
- 	  code = ipa_get_jf_pass_through_operation (jfunc);
-+	  if (code != NOP_EXPR
-+	      && !expr_type_first_operand_type_p (code))
-+	    {
-+	      if (dump_file && (dump_flags & TDF_DETAILS))
-+		fprintf (dump_file, "Setting dest_lattice to bottom, because "
-+			 "the operation involved in computing param %i of %s "
-+			 "does not preserve types.\n",
-+		 idx, cs->callee->dump_name ());
-+	      return dest_lattice->set_to_bottom ();
-+	    }
- 	  src_idx = ipa_get_jf_pass_through_formal_id (jfunc);
- 	  if (code != NOP_EXPR)
- 	    operand = ipa_get_jf_pass_through_operand (jfunc);
-@@ -2554,6 +2565,12 @@ propagate_bits_across_jump_function (cgraph_edge *cs, int idx,
- 	  bool drop_all_ones
- 	    = keep_null && !src_lats->bits_lattice.known_nonzero_p ();
- 
-+	  tree arg_type = ipa_get_type (caller_info, src_idx);
-+	  if (!arg_type)
-+	    return dest_lattice->set_to_bottom ();
-+	  unsigned precision = TYPE_PRECISION (arg_type);
-+	  signop sgn = TYPE_SIGN (arg_type);
-+
- 	  return dest_lattice->meet_with (src_lats->bits_lattice, precision,
- 					  sgn, code, operand, drop_all_ones);
- 	}
-@@ -2570,7 +2587,8 @@ propagate_bits_across_jump_function (cgraph_edge *cs, int idx,
- 	    = widest_int::from (bm.mask (), TYPE_SIGN (parm_type));
- 	  widest_int value
- 	    = widest_int::from (bm.value (), TYPE_SIGN (parm_type));
--	  return dest_lattice->meet_with (value, mask, precision);
-+	  return dest_lattice->meet_with (value, mask,
-+					  TYPE_PRECISION (parm_type));
- 	}
-     }
-   return dest_lattice->set_to_bottom ();
-diff --git a/gcc/testsuite/gcc.dg/ipa/pr119318.c b/gcc/testsuite/gcc.dg/ipa/pr119318.c
-new file mode 100644
-index 00000000000..8e62ec5e350
---- /dev/null
-+++ b/gcc/testsuite/gcc.dg/ipa/pr119318.c
-@@ -0,0 +1,38 @@
-+/* { dg-do run } */
-+/* { dg-require-effective-target int128 } */
-+/* { dg-additional-options "-Wno-psabi -w" } */
-+/* { dg-options "-Wno-psabi -O2" } */
-+
-+typedef unsigned V __attribute__((vector_size (64)));
-+typedef unsigned __int128 W __attribute__((vector_size (64)));
-+
-+W a;
-+W b;
-+W c = { -0xffff, -0xffff, -0xffff, -0xffff };
-+
-+static __attribute__((__noinline__, __noclone__)) W
-+bar (unsigned __int128 u)
-+{
-+  return u + c;
-+}
-+
-+static inline W
-+foo (unsigned short s, V v)
-+{
-+  V y = (V) bar ((unsigned short) ~s);
-+  v >>= y;
-+  b ^= (W) a;
-+  v *= v;
-+  return (W) v + b;
-+}
-+
-+
-+int
-+main ()
-+{
-+  W x = foo (0, (V) { 0, 5 });
-+  for (unsigned i = 0; i < sizeof(x)/sizeof(x[0]); i++)
-+    if (x[i] != (i ? 0 : 0x1900000000))
-+      __builtin_abort();
-+  return 0;
-+}
-diff --git a/gcc/tree.cc b/gcc/tree.cc
-index eccfcc89da4..6a5d9d4d741 100644
---- a/gcc/tree.cc
-+++ b/gcc/tree.cc
-@@ -15051,6 +15051,7 @@ expr_type_first_operand_type_p (tree_code code)
-     case BIT_IOR_EXPR:
-     case BIT_XOR_EXPR:
-     case BIT_AND_EXPR:
-+    case POINTER_PLUS_EXPR:
- 
-     case LSHIFT_EXPR:
-     case RSHIFT_EXPR:
--- 
-2.48.1
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index f2463fa..678df05 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,5 +1,6 @@
 55	????
 
+	- 82_all_PR119318-ipa-cp.patch
 	- 84_all_PR116975.patch
 	+ 84_all_PR116975-GDCFLAGS.patch
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-14 20:51 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-14 20:51 UTC (permalink / raw
  To: gentoo-commits
commit:     146716b7b6b50240e891d78bab4eac96e0eb21a2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 14 20:51:42 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Apr 14 20:51:42 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=146716b7
15.0.0: add 85_all_PR119614-ipa-vrp-lto.patch
Hopefully fixes protobuf with LTO.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch | 257 ++++++++++++++++++++++++
 1 file changed, 257 insertions(+)
diff --git a/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch b/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
new file mode 100644
index 0000000..86fb953
--- /dev/null
+++ b/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
@@ -0,0 +1,257 @@
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c27
+diff --git a/gcc/ipa-cp.cc b/gcc/ipa-cp.cc
+index 26b1496f29b..9b47c6c364d 100644
+--- a/gcc/ipa-cp.cc
++++ b/gcc/ipa-cp.cc
+@@ -6334,6 +6334,13 @@ ipcp_store_vr_results (void)
+ 
+       if (info->ipcp_orig_node)
+ 	info = ipa_node_params_sum->get (info->ipcp_orig_node);
++
++      if (do_vr && info->m_return_vr)
++	{
++	  clone_info *clone_info = clone_info::get_create (node);
++	  clone_info->m_return_vr = info->m_return_vr;
++	}
++
+       if (info->lattices.is_empty ())
+ 	/* Newly expanded artificial thunks do not have lattices.  */
+ 	continue;
+diff --git a/gcc/ipa-prop.cc b/gcc/ipa-prop.cc
+index 49d68ab044b..d44c360b292 100644
+--- a/gcc/ipa-prop.cc
++++ b/gcc/ipa-prop.cc
+@@ -2323,6 +2323,26 @@ ipa_get_value_range (const vrange &tmp)
+   return vr;
+ }
+ 
++/* Read an IPA-VR from IB and DATA_IN.  If it does not contain useful info,
++   return nullptr. If it is already in the hash of IPA-VRs, return the already
++   present value, otherwise add it to the hash and return this new value.  */
++
++ipa_vr *streamer_read_and_hash (lto_input_block *ib, data_in *data_in)
++{
++  ipa_vr ivr;
++  ivr.streamer_read (ib, data_in);
++  if (ivr.known_p ())
++    {
++      if (!ipa_vr_hash_table)
++	ipa_vr_hash_table = hash_table<ipa_vr_ggc_hash_traits>::create_ggc (37);
++
++      value_range tmp;
++      ivr.get_vrange (tmp);
++      return ipa_get_value_range (tmp);
++    }
++  return nullptr;
++}
++
+ /* Assign to JF a pointer to a range just like TMP but either fetch a
+    copy from ipa_vr_hash_table or allocate a new on in GC memory.  */
+ 
+@@ -3312,6 +3332,14 @@ ipa_analyze_node (struct cgraph_node *node)
+   analysis_dom_walker (&fbi).walk (ENTRY_BLOCK_PTR_FOR_FN (cfun));
+   disable_ranger (cfun);
+ 
++  ipa_return_value_summary *rvs;
++
++  if (ipa_return_value_sum
++      && (rvs = ipa_return_value_sum->get (node)))
++    /* The VRs in the summary already live in the cache, no need to go through
++       ipa_get_value_range.  */
++    info->m_return_vr = rvs->vr;
++
+   ipa_release_body_info (&fbi);
+   free_dominance_info (CDI_DOMINATORS);
+   pop_cfun ();
+@@ -4793,6 +4821,8 @@ ipa_node_params_t::duplicate(cgraph_node *, cgraph_node *,
+   new_info->known_csts = old_info->known_csts.copy ();
+   new_info->known_contexts = old_info->known_contexts.copy ();
+ 
++  new_info->m_return_vr = old_info->m_return_vr;
++
+   new_info->analysis_done = old_info->analysis_done;
+   new_info->node_enqueued = old_info->node_enqueued;
+   new_info->versionable = old_info->versionable;
+@@ -5272,6 +5302,15 @@ ipa_write_node_info (struct output_block *ob, struct cgraph_node *node)
+   streamer_write_uhwi (ob, ipa_get_param_count (info));
+   for (j = 0; j < ipa_get_param_count (info); j++)
+     streamer_write_uhwi (ob, ipa_get_param_move_cost (info, j));
++  if (info->m_return_vr)
++    info->m_return_vr->streamer_write (ob);
++  else
++    {
++      bp = bitpack_create (ob->main_stream);
++      bp_pack_value (&bp, false, 1);
++      streamer_write_bitpack (&bp);
++    }
++
+   bp = bitpack_create (ob->main_stream);
+   gcc_assert (info->analysis_done
+ 	      || ipa_get_param_count (info) == 0);
+@@ -5407,6 +5446,15 @@ ipa_read_node_info (class lto_input_block *ib, struct cgraph_node *node,
+     for (k = 0; k < param_count; k++)
+       streamer_read_uhwi (ib);
+ 
++  ipa_vr rvr;
++  rvr.streamer_read (ib, data_in);
++  if (prevails && rvr.known_p ())
++    {
++      value_range tmp;
++      rvr.get_vrange (tmp);
++      info->m_return_vr = ipa_get_value_range (tmp);
++    }
++
+   bp = streamer_read_bitpack (ib);
+   for (k = 0; k < param_count; k++)
+     {
+@@ -6218,7 +6266,7 @@ bool
+ ipa_return_value_range (value_range &range, tree decl)
+ {
+   cgraph_node *n = cgraph_node::get (decl);
+-  if (!n || !ipa_return_value_sum)
++  if (!n || (!ipa_return_value_sum))
+     return false;
+   enum availability avail;
+   n = n->ultimate_alias_target (&avail);
+@@ -6226,11 +6274,25 @@ ipa_return_value_range (value_range &range, tree decl)
+     return false;
+   if (n->decl != decl && !useless_type_conversion_p (TREE_TYPE (decl), TREE_TYPE (n->decl)))
+     return false;
+-  ipa_return_value_summary *v = ipa_return_value_sum->get (n);
+-  if (!v)
+-    return false;
+-  v->vr->get_vrange (range);
+-  return true;
++
++  if (ipa_return_value_sum)
++    {
++      ipa_return_value_summary *v = ipa_return_value_sum->get (n);
++      if (v)
++	{
++	  v->vr->get_vrange (range);
++	  return true;
++	}
++    }
++
++  clone_info *info = clone_info::get (n);
++  if (info && info->m_return_vr)
++    {
++      gcc_assert (info->m_return_vr->known_p ());
++      info->m_return_vr->get_vrange (range);
++      return true;
++    }
++  return false;
+ }
+ 
+ /* Reset all state within ipa-prop.cc so that we can rerun the compiler
+diff --git a/gcc/ipa-prop.h b/gcc/ipa-prop.h
+index 3bd442fff39..8dc8e2f2ab5 100644
+--- a/gcc/ipa-prop.h
++++ b/gcc/ipa-prop.h
+@@ -653,6 +653,9 @@ public:
+   /* If this node is an ipa-cp clone, these are the known polymorphic contexts
+      that describe what it has been specialized for.  */
+   vec<ipa_polymorphic_call_context> GTY((skip)) known_contexts;
++  /* If non-NULL, the known value range of the return value of this
++     function.  */
++  class ipa_vr *m_return_vr;
+   /* Whether the param uses analysis and jump function computation has already
+      been performed.  */
+   unsigned analysis_done : 1;
+@@ -679,10 +682,10 @@ public:
+ inline
+ ipa_node_params::ipa_node_params ()
+ : descriptors (NULL), lattices (vNULL), ipcp_orig_node (NULL),
+-  known_csts (vNULL), known_contexts (vNULL), analysis_done (0),
+-  node_enqueued (0), do_clone_for_all_contexts (0), is_all_contexts_clone (0),
+-  node_dead (0), node_within_scc (0), node_is_self_scc (0),
+-  node_calling_single_call (0), versionable (0)
++  known_csts (vNULL), known_contexts (vNULL), m_return_vr (nullptr),
++  analysis_done (0), node_enqueued (0), do_clone_for_all_contexts (0),
++  is_all_contexts_clone (0), node_dead (0), node_within_scc (0),
++  node_is_self_scc (0), node_calling_single_call (0), versionable (0)
+ {
+ }
+ 
+@@ -1275,6 +1278,7 @@ bool unadjusted_ptr_and_unit_offset (tree op, tree *ret,
+ 				     poly_int64 *offset_ret);
+ void ipa_get_range_from_ip_invariant (vrange &r, tree val, cgraph_node *node);
+ void ipa_prop_cc_finalize (void);
++ipa_vr *streamer_read_and_hash (lto_input_block *ib, data_in *data_in);
+ 
+ /* From tree-sra.cc:  */
+ tree build_ref_for_offset (location_t, tree, poly_int64, bool, tree,
+diff --git a/gcc/lto-cgraph.cc b/gcc/lto-cgraph.cc
+index ac835a435ec..877a9a496cc 100644
+--- a/gcc/lto-cgraph.cc
++++ b/gcc/lto-cgraph.cc
+@@ -44,6 +44,11 @@ along with GCC; see the file COPYING3.  If not see
+ #include "symbol-summary.h"
+ #include "symtab-thunks.h"
+ #include "symtab-clones.h"
++#include "sreal.h"
++#include "value-range.h"
++#include "value-range-storage.h"
++#include "ipa-cp.h"
++#include "ipa-prop.h"
+ 
+ /* True when asm nodes has been output.  */
+ bool asm_nodes_output = false;
+@@ -2065,6 +2070,15 @@ output_node_opt_summary (struct output_block *ob,
+ 	stream_write_tree (ob, map->new_tree, true);
+       }
+ 
++  if (info && info->m_return_vr)
++    info->m_return_vr->streamer_write (ob);
++  else
++    {
++      bp = bitpack_create (ob->main_stream);
++      bp_pack_value (&bp, false, 1);
++      streamer_write_bitpack (&bp);
++    }
++
+   if (lto_symtab_encoder_in_partition_p (encoder, node))
+     {
+       for (e = node->callees; e; e = e->next_callee)
+@@ -2181,6 +2195,9 @@ input_node_opt_summary (struct cgraph_node *node,
+       map->parm_num = streamer_read_uhwi (ib_main);
+       map->new_tree = stream_read_tree (ib_main, data_in);
+     }
++
++  info->m_return_vr = streamer_read_and_hash (ib_main, data_in);
++
+   for (e = node->callees; e; e = e->next_callee)
+     input_edge_opt_summary (e, ib_main);
+   for (e = node->indirect_calls; e; e = e->next_callee)
+diff --git a/gcc/symtab-clones.h b/gcc/symtab-clones.h
+index 362bcb63dd1..eb5167d7506 100644
+--- a/gcc/symtab-clones.h
++++ b/gcc/symtab-clones.h
+@@ -21,12 +21,15 @@ along with GCC; see the file COPYING3.  If not see
+ #ifndef GCC_SYMTAB_CLONES_H
+ #define GCC_SYMTAB_CLONES_H
+ 
++class ipa_vr;
++
+ struct GTY(()) clone_info
+ {
+   /* Constructor.  */
+   clone_info ()
+     : tree_map (NULL),
+-      param_adjustments (NULL)
++      param_adjustments (NULL),
++    m_return_vr (nullptr)
+   {
+   }
+   /* Constants discovered by IPA-CP, i.e. which parameter should be replaced
+@@ -35,6 +38,10 @@ struct GTY(()) clone_info
+   /* Parameter modification that IPA-SRA decided to perform.  */
+   ipa_param_adjustments *param_adjustments;
+ 
++  /* If non-NULL, the known value range of the return value of this
++     function.  */
++  ipa_vr *m_return_vr;
++
+   /* Return clone_info, if available.  */
+   static clone_info *get (cgraph_node *node);
+ 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-14 21:06 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-14 21:06 UTC (permalink / raw
  To: gentoo-commits
commit:     e5878df66ea0cd3ae77833834183b5a0b52ee2a9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 14 21:05:58 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Apr 14 21:06:20 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=e5878df6
15.0.0: add 85_all_PR119614-ipa-vrp-lto-inc.patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 .../gentoo/85_all_PR119614-ipa-vrp-lto-inc.patch   | 93 ++++++++++++++++++++++
 1 file changed, 93 insertions(+)
diff --git a/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto-inc.patch b/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto-inc.patch
new file mode 100644
index 0000000..29715be
--- /dev/null
+++ b/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto-inc.patch
@@ -0,0 +1,93 @@
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c28
+--- a/gcc/symtab-clones.h	2025-04-14 22:51:13.172434417 +0200
++++ b/gcc/symtab-clones.h	2025-04-14 22:55:11.461235984 +0200
+@@ -29,7 +29,7 @@ struct GTY(()) clone_info
+   clone_info ()
+     : tree_map (NULL),
+       param_adjustments (NULL),
+-    m_return_vr (nullptr)
++      m_return_vr (nullptr)
+   {
+   }
+   /* Constants discovered by IPA-CP, i.e. which parameter should be replaced
+--- a/gcc/ipa-prop.cc	2025-04-14 22:51:13.172434417 +0200
++++ b/gcc/ipa-prop.cc	2025-04-14 22:54:56.094442247 +0200
+@@ -2324,17 +2324,19 @@ ipa_get_value_range (const vrange &tmp)
+ }
+ 
+ /* Read an IPA-VR from IB and DATA_IN.  If it does not contain useful info,
+-   return nullptr. If it is already in the hash of IPA-VRs, return the already
++   return nullptr.  If it is already in the hash of IPA-VRs, return the already
+    present value, otherwise add it to the hash and return this new value.  */
+ 
+-ipa_vr *streamer_read_and_hash (lto_input_block *ib, data_in *data_in)
++ipa_vr *
++streamer_read_and_hash (lto_input_block *ib, data_in *data_in)
+ {
+   ipa_vr ivr;
+   ivr.streamer_read (ib, data_in);
+   if (ivr.known_p ())
+     {
+       if (!ipa_vr_hash_table)
+-	ipa_vr_hash_table = hash_table<ipa_vr_ggc_hash_traits>::create_ggc (37);
++	ipa_vr_hash_table
++	  = hash_table<ipa_vr_ggc_hash_traits>::create_ggc (37);
+ 
+       value_range tmp;
+       ivr.get_vrange (tmp);
+@@ -6266,7 +6268,7 @@ bool
+ ipa_return_value_range (value_range &range, tree decl)
+ {
+   cgraph_node *n = cgraph_node::get (decl);
+-  if (!n || (!ipa_return_value_sum))
++  if (!n)
+     return false;
+   enum availability avail;
+   n = n->ultimate_alias_target (&avail);
+@@ -6277,8 +6279,7 @@ ipa_return_value_range (value_range &ran
+ 
+   if (ipa_return_value_sum)
+     {
+-      ipa_return_value_summary *v = ipa_return_value_sum->get (n);
+-      if (v)
++      if (ipa_return_value_summary *v = ipa_return_value_sum->get (n))
+ 	{
+ 	  v->vr->get_vrange (range);
+ 	  return true;
+--- a/gcc/testsuite/g++.dg/lto/pr119614_0.C	2025-04-14 22:52:58.938014778 +0200
++++ b/gcc/testsuite/g++.dg/lto/pr119614_0.C	2025-04-14 22:52:58.938014778 +0200
+@@ -0,0 +1,34 @@
++// PR tree-optimization/119614
++// { dg-lto-do link }
++// { dg-lto-options { { -O2 -fPIC -flto -flto-partition=max } } }
++// { dg-require-effective-target shared }
++// { dg-require-effective-target fpic }
++// { dg-require-effective-target musttail }
++// { dg-extra-ld-options "-shared" }
++
++struct S {} b;
++char *foo ();
++int e, g;
++void bar ();
++void corge (S);
++
++[[gnu::noinline]] static char *
++baz ()
++{
++  bar ();
++  return 0;
++}
++
++const char *
++qux ()
++{
++  if (e)
++    {
++      S a = b;
++      corge (a);
++      if (g)
++        return 0;
++      [[gnu::musttail]] return baz ();
++    }
++  return foo ();
++}
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-14 22:44 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-14 22:44 UTC (permalink / raw
  To: gentoo-commits
commit:     a4dcb99bde7d331446dc3cab28870aebc023fc92
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 14 22:43:52 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Apr 14 22:43:52 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=a4dcb99b
15.0.0: rename ipa-vrp-lto-inc patch
Signed-off-by: Sam James <sam <AT> gentoo.org>
 ...PR119614-ipa-vrp-lto-inc.patch => 86_all_PR119614-ipa-vrp-lto.patch} | 0
 15.0.0/gentoo/README.history                                            | 2 ++
 2 files changed, 2 insertions(+)
diff --git a/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto-inc.patch b/15.0.0/gentoo/86_all_PR119614-ipa-vrp-lto.patch
similarity index 100%
rename from 15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto-inc.patch
rename to 15.0.0/gentoo/86_all_PR119614-ipa-vrp-lto.patch
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 678df05..fb90c7b 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -3,6 +3,8 @@
 	- 82_all_PR119318-ipa-cp.patch
 	- 84_all_PR116975.patch
 	+ 84_all_PR116975-GDCFLAGS.patch
+	+ 85_all_PR119614-ipa-vrp-lto.patch
+	+ 86_all_PR119614-ipa-vrp-lto-inc.patch
 
 54	13 April 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-14 22:47 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-14 22:47 UTC (permalink / raw
  To: gentoo-commits
commit:     323b1da8d9a5c1c3ac9bc1e9548dd7601aad6356
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 14 22:47:10 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Apr 14 22:47:10 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=323b1da8
15.0.0: add ICE patch
Bug: https://gcc.gnu.org/PR119803
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/87_all_PR119803-vrp.patch | 19 +++++++++++++++++++
 15.0.0/gentoo/README.history            |  1 +
 2 files changed, 20 insertions(+)
diff --git a/15.0.0/gentoo/87_all_PR119803-vrp.patch b/15.0.0/gentoo/87_all_PR119803-vrp.patch
new file mode 100644
index 0000000..9f71cca
--- /dev/null
+++ b/15.0.0/gentoo/87_all_PR119803-vrp.patch
@@ -0,0 +1,19 @@
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119803#c6
+--- a/gcc/ipa-cp.cc	2025-04-14 22:51:13.171434430 +0200
++++ b/gcc/ipa-cp.cc	2025-04-14 23:42:40.515006966 +0200
+@@ -923,13 +923,13 @@ ipcp_bits_lattice::meet_with_1 (widest_i
+   m_mask = (m_mask | mask) | (m_value ^ value);
+   if (drop_all_ones)
+     m_mask |= m_value;
+-  m_value &= ~m_mask;
+ 
+-  widest_int cap_mask = wi::bit_not (wi::sub (wi::lshift (1, precision), 1));
++  widest_int cap_mask = wi::shifted_mask <widest_int> (0, precision, true);
+   m_mask |= cap_mask;
+   if (wi::sext (m_mask, precision) == -1)
+     return set_to_bottom ();
+ 
++  m_value &= ~m_mask;
+   return m_mask != old_mask;
+ }
+ 
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index fb90c7b..9297835 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -5,6 +5,7 @@
 	+ 84_all_PR116975-GDCFLAGS.patch
 	+ 85_all_PR119614-ipa-vrp-lto.patch
 	+ 86_all_PR119614-ipa-vrp-lto-inc.patch
+	+ 87_all_PR119803-vrp.patch
 
 54	13 April 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-14 22:59 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-14 22:59 UTC (permalink / raw
  To: gentoo-commits
commit:     ddc48fc0fbe2ed912534bd51afa10d6b9a5cf06c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 14 22:59:06 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Apr 14 22:59:06 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ddc48fc0
15.0.0: update 85_all_PR119614-ipa-vrp-lto.patch
.. and drop incremental patch as it is folded in now.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch | 88 ++++++++++++++++++-----
 15.0.0/gentoo/86_all_PR119614-ipa-vrp-lto.patch | 93 -------------------------
 15.0.0/gentoo/README.history                    |  1 -
 3 files changed, 71 insertions(+), 111 deletions(-)
diff --git a/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch b/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
index 86fb953..3049a2f 100644
--- a/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
+++ b/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
@@ -1,4 +1,4 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c27
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c32
 diff --git a/gcc/ipa-cp.cc b/gcc/ipa-cp.cc
 index 26b1496f29b..9b47c6c364d 100644
 --- a/gcc/ipa-cp.cc
@@ -18,18 +18,19 @@ index 26b1496f29b..9b47c6c364d 100644
  	/* Newly expanded artificial thunks do not have lattices.  */
  	continue;
 diff --git a/gcc/ipa-prop.cc b/gcc/ipa-prop.cc
-index 49d68ab044b..d44c360b292 100644
+index 49d68ab044b..eb757658ad7 100644
 --- a/gcc/ipa-prop.cc
 +++ b/gcc/ipa-prop.cc
-@@ -2323,6 +2323,26 @@ ipa_get_value_range (const vrange &tmp)
+@@ -2323,6 +2323,27 @@ ipa_get_value_range (const vrange &tmp)
    return vr;
  }
  
 +/* Read an IPA-VR from IB and DATA_IN.  If it does not contain useful info,
-+   return nullptr. If it is already in the hash of IPA-VRs, return the already
++   return nullptr.  If it is already in the hash of IPA-VRs, return the already
 +   present value, otherwise add it to the hash and return this new value.  */
 +
-+ipa_vr *streamer_read_and_hash (lto_input_block *ib, data_in *data_in)
++ipa_vr *
++streamer_read_and_hash (lto_input_block *ib, data_in *data_in)
 +{
 +  ipa_vr ivr;
 +  ivr.streamer_read (ib, data_in);
@@ -48,7 +49,7 @@ index 49d68ab044b..d44c360b292 100644
  /* Assign to JF a pointer to a range just like TMP but either fetch a
     copy from ipa_vr_hash_table or allocate a new on in GC memory.  */
  
-@@ -3312,6 +3332,14 @@ ipa_analyze_node (struct cgraph_node *node)
+@@ -3312,6 +3333,14 @@ ipa_analyze_node (struct cgraph_node *node)
    analysis_dom_walker (&fbi).walk (ENTRY_BLOCK_PTR_FOR_FN (cfun));
    disable_ranger (cfun);
  
@@ -63,7 +64,7 @@ index 49d68ab044b..d44c360b292 100644
    ipa_release_body_info (&fbi);
    free_dominance_info (CDI_DOMINATORS);
    pop_cfun ();
-@@ -4793,6 +4821,8 @@ ipa_node_params_t::duplicate(cgraph_node *, cgraph_node *,
+@@ -4793,6 +4822,8 @@ ipa_node_params_t::duplicate(cgraph_node *, cgraph_node *,
    new_info->known_csts = old_info->known_csts.copy ();
    new_info->known_contexts = old_info->known_contexts.copy ();
  
@@ -72,7 +73,7 @@ index 49d68ab044b..d44c360b292 100644
    new_info->analysis_done = old_info->analysis_done;
    new_info->node_enqueued = old_info->node_enqueued;
    new_info->versionable = old_info->versionable;
-@@ -5272,6 +5302,15 @@ ipa_write_node_info (struct output_block *ob, struct cgraph_node *node)
+@@ -5272,6 +5303,15 @@ ipa_write_node_info (struct output_block *ob, struct cgraph_node *node)
    streamer_write_uhwi (ob, ipa_get_param_count (info));
    for (j = 0; j < ipa_get_param_count (info); j++)
      streamer_write_uhwi (ob, ipa_get_param_move_cost (info, j));
@@ -88,7 +89,7 @@ index 49d68ab044b..d44c360b292 100644
    bp = bitpack_create (ob->main_stream);
    gcc_assert (info->analysis_done
  	      || ipa_get_param_count (info) == 0);
-@@ -5407,6 +5446,15 @@ ipa_read_node_info (class lto_input_block *ib, struct cgraph_node *node,
+@@ -5407,6 +5447,15 @@ ipa_read_node_info (class lto_input_block *ib, struct cgraph_node *node,
      for (k = 0; k < param_count; k++)
        streamer_read_uhwi (ib);
  
@@ -104,16 +105,16 @@ index 49d68ab044b..d44c360b292 100644
    bp = streamer_read_bitpack (ib);
    for (k = 0; k < param_count; k++)
      {
-@@ -6218,7 +6266,7 @@ bool
+@@ -6218,7 +6267,7 @@ bool
  ipa_return_value_range (value_range &range, tree decl)
  {
    cgraph_node *n = cgraph_node::get (decl);
 -  if (!n || !ipa_return_value_sum)
-+  if (!n || (!ipa_return_value_sum))
++  if (!n)
      return false;
    enum availability avail;
    n = n->ultimate_alias_target (&avail);
-@@ -6226,11 +6274,25 @@ ipa_return_value_range (value_range &range, tree decl)
+@@ -6226,11 +6275,24 @@ ipa_return_value_range (value_range &range, tree decl)
      return false;
    if (n->decl != decl && !useless_type_conversion_p (TREE_TYPE (decl), TREE_TYPE (n->decl)))
      return false;
@@ -125,8 +126,7 @@ index 49d68ab044b..d44c360b292 100644
 +
 +  if (ipa_return_value_sum)
 +    {
-+      ipa_return_value_summary *v = ipa_return_value_sum->get (n);
-+      if (v)
++      if (ipa_return_value_summary *v = ipa_return_value_sum->get (n))
 +	{
 +	  v->vr->get_vrange (range);
 +	  return true;
@@ -182,7 +182,7 @@ index 3bd442fff39..8dc8e2f2ab5 100644
  /* From tree-sra.cc:  */
  tree build_ref_for_offset (location_t, tree, poly_int64, bool, tree,
 diff --git a/gcc/lto-cgraph.cc b/gcc/lto-cgraph.cc
-index ac835a435ec..877a9a496cc 100644
+index ac835a435ec..a99e7227528 100644
 --- a/gcc/lto-cgraph.cc
 +++ b/gcc/lto-cgraph.cc
 @@ -44,6 +44,11 @@ along with GCC; see the file COPYING3.  If not see
@@ -197,6 +197,20 @@ index ac835a435ec..877a9a496cc 100644
  
  /* True when asm nodes has been output.  */
  bool asm_nodes_output = false;
+@@ -1992,10 +1997,10 @@ input_offload_tables (bool do_force_output)
+ static int
+ output_cgraph_opt_summary_p (struct cgraph_node *node)
+ {
+-  if (node->clone_of || node->former_clone_of)
+-    return true;
+   clone_info *info = clone_info::get (node);
+-  return info && (info->tree_map || info->param_adjustments);
++  return info && (info->tree_map
++		  || info->param_adjustments
++		  || info->m_return_vr);
+ }
+ 
+ /* Output optimization summary for EDGE to OB.  */
 @@ -2065,6 +2070,15 @@ output_node_opt_summary (struct output_block *ob,
  	stream_write_tree (ob, map->new_tree, true);
        }
@@ -224,7 +238,7 @@ index ac835a435ec..877a9a496cc 100644
      input_edge_opt_summary (e, ib_main);
    for (e = node->indirect_calls; e; e = e->next_callee)
 diff --git a/gcc/symtab-clones.h b/gcc/symtab-clones.h
-index 362bcb63dd1..eb5167d7506 100644
+index 362bcb63dd1..a63036fc94f 100644
 --- a/gcc/symtab-clones.h
 +++ b/gcc/symtab-clones.h
 @@ -21,12 +21,15 @@ along with GCC; see the file COPYING3.  If not see
@@ -240,7 +254,7 @@ index 362bcb63dd1..eb5167d7506 100644
      : tree_map (NULL),
 -      param_adjustments (NULL)
 +      param_adjustments (NULL),
-+    m_return_vr (nullptr)
++      m_return_vr (nullptr)
    {
    }
    /* Constants discovered by IPA-CP, i.e. which parameter should be replaced
@@ -255,3 +269,43 @@ index 362bcb63dd1..eb5167d7506 100644
    /* Return clone_info, if available.  */
    static clone_info *get (cgraph_node *node);
  
+diff --git a/gcc/testsuite/g++.dg/lto/pr119614_0.C b/gcc/testsuite/g++.dg/lto/pr119614_0.C
+new file mode 100644
+index 00000000000..09c07fbf566
+--- /dev/null
++++ b/gcc/testsuite/g++.dg/lto/pr119614_0.C
+@@ -0,0 +1,34 @@
++// PR tree-optimization/119614
++// { dg-lto-do link }
++// { dg-lto-options { { -O2 -fPIC -flto -flto-partition=max } } }
++// { dg-require-effective-target shared }
++// { dg-require-effective-target fpic }
++// { dg-require-effective-target musttail }
++// { dg-extra-ld-options "-shared" }
++
++struct S {} b;
++char *foo ();
++int e, g;
++void bar ();
++void corge (S);
++
++[[gnu::noinline]] static char *
++baz ()
++{
++  bar ();
++  return 0;
++}
++
++const char *
++qux ()
++{
++  if (e)
++    {
++      S a = b;
++      corge (a);
++      if (g)
++        return 0;
++      [[gnu::musttail]] return baz ();
++    }
++  return foo ();
++}
diff --git a/15.0.0/gentoo/86_all_PR119614-ipa-vrp-lto.patch b/15.0.0/gentoo/86_all_PR119614-ipa-vrp-lto.patch
deleted file mode 100644
index 29715be..0000000
--- a/15.0.0/gentoo/86_all_PR119614-ipa-vrp-lto.patch
+++ /dev/null
@@ -1,93 +0,0 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c28
---- a/gcc/symtab-clones.h	2025-04-14 22:51:13.172434417 +0200
-+++ b/gcc/symtab-clones.h	2025-04-14 22:55:11.461235984 +0200
-@@ -29,7 +29,7 @@ struct GTY(()) clone_info
-   clone_info ()
-     : tree_map (NULL),
-       param_adjustments (NULL),
--    m_return_vr (nullptr)
-+      m_return_vr (nullptr)
-   {
-   }
-   /* Constants discovered by IPA-CP, i.e. which parameter should be replaced
---- a/gcc/ipa-prop.cc	2025-04-14 22:51:13.172434417 +0200
-+++ b/gcc/ipa-prop.cc	2025-04-14 22:54:56.094442247 +0200
-@@ -2324,17 +2324,19 @@ ipa_get_value_range (const vrange &tmp)
- }
- 
- /* Read an IPA-VR from IB and DATA_IN.  If it does not contain useful info,
--   return nullptr. If it is already in the hash of IPA-VRs, return the already
-+   return nullptr.  If it is already in the hash of IPA-VRs, return the already
-    present value, otherwise add it to the hash and return this new value.  */
- 
--ipa_vr *streamer_read_and_hash (lto_input_block *ib, data_in *data_in)
-+ipa_vr *
-+streamer_read_and_hash (lto_input_block *ib, data_in *data_in)
- {
-   ipa_vr ivr;
-   ivr.streamer_read (ib, data_in);
-   if (ivr.known_p ())
-     {
-       if (!ipa_vr_hash_table)
--	ipa_vr_hash_table = hash_table<ipa_vr_ggc_hash_traits>::create_ggc (37);
-+	ipa_vr_hash_table
-+	  = hash_table<ipa_vr_ggc_hash_traits>::create_ggc (37);
- 
-       value_range tmp;
-       ivr.get_vrange (tmp);
-@@ -6266,7 +6268,7 @@ bool
- ipa_return_value_range (value_range &range, tree decl)
- {
-   cgraph_node *n = cgraph_node::get (decl);
--  if (!n || (!ipa_return_value_sum))
-+  if (!n)
-     return false;
-   enum availability avail;
-   n = n->ultimate_alias_target (&avail);
-@@ -6277,8 +6279,7 @@ ipa_return_value_range (value_range &ran
- 
-   if (ipa_return_value_sum)
-     {
--      ipa_return_value_summary *v = ipa_return_value_sum->get (n);
--      if (v)
-+      if (ipa_return_value_summary *v = ipa_return_value_sum->get (n))
- 	{
- 	  v->vr->get_vrange (range);
- 	  return true;
---- a/gcc/testsuite/g++.dg/lto/pr119614_0.C	2025-04-14 22:52:58.938014778 +0200
-+++ b/gcc/testsuite/g++.dg/lto/pr119614_0.C	2025-04-14 22:52:58.938014778 +0200
-@@ -0,0 +1,34 @@
-+// PR tree-optimization/119614
-+// { dg-lto-do link }
-+// { dg-lto-options { { -O2 -fPIC -flto -flto-partition=max } } }
-+// { dg-require-effective-target shared }
-+// { dg-require-effective-target fpic }
-+// { dg-require-effective-target musttail }
-+// { dg-extra-ld-options "-shared" }
-+
-+struct S {} b;
-+char *foo ();
-+int e, g;
-+void bar ();
-+void corge (S);
-+
-+[[gnu::noinline]] static char *
-+baz ()
-+{
-+  bar ();
-+  return 0;
-+}
-+
-+const char *
-+qux ()
-+{
-+  if (e)
-+    {
-+      S a = b;
-+      corge (a);
-+      if (g)
-+        return 0;
-+      [[gnu::musttail]] return baz ();
-+    }
-+  return foo ();
-+}
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 9297835..8e237f9 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -4,7 +4,6 @@
 	- 84_all_PR116975.patch
 	+ 84_all_PR116975-GDCFLAGS.patch
 	+ 85_all_PR119614-ipa-vrp-lto.patch
-	+ 86_all_PR119614-ipa-vrp-lto-inc.patch
 	+ 87_all_PR119803-vrp.patch
 
 54	13 April 2025
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-15 16:40 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-15 16:40 UTC (permalink / raw
  To: gentoo-commits
commit:     14fba9f4c43c849a94ffb97bf2a7ba924ed3af9c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 15 16:40:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr 15 16:40:08 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=14fba9f4
15.0.0: drop 87_all_PR119803-vrp.patch
A fuller version was merged upstream.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/87_all_PR119803-vrp.patch | 19 -------------------
 15.0.0/gentoo/README.history            |  1 -
 2 files changed, 20 deletions(-)
diff --git a/15.0.0/gentoo/87_all_PR119803-vrp.patch b/15.0.0/gentoo/87_all_PR119803-vrp.patch
deleted file mode 100644
index 9f71cca..0000000
--- a/15.0.0/gentoo/87_all_PR119803-vrp.patch
+++ /dev/null
@@ -1,19 +0,0 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119803#c6
---- a/gcc/ipa-cp.cc	2025-04-14 22:51:13.171434430 +0200
-+++ b/gcc/ipa-cp.cc	2025-04-14 23:42:40.515006966 +0200
-@@ -923,13 +923,13 @@ ipcp_bits_lattice::meet_with_1 (widest_i
-   m_mask = (m_mask | mask) | (m_value ^ value);
-   if (drop_all_ones)
-     m_mask |= m_value;
--  m_value &= ~m_mask;
- 
--  widest_int cap_mask = wi::bit_not (wi::sub (wi::lshift (1, precision), 1));
-+  widest_int cap_mask = wi::shifted_mask <widest_int> (0, precision, true);
-   m_mask |= cap_mask;
-   if (wi::sext (m_mask, precision) == -1)
-     return set_to_bottom ();
- 
-+  m_value &= ~m_mask;
-   return m_mask != old_mask;
- }
- 
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 8e237f9..35249b2 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -4,7 +4,6 @@
 	- 84_all_PR116975.patch
 	+ 84_all_PR116975-GDCFLAGS.patch
 	+ 85_all_PR119614-ipa-vrp-lto.patch
-	+ 87_all_PR119803-vrp.patch
 
 54	13 April 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-15 21:09 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-15 21:09 UTC (permalink / raw
  To: gentoo-commits
commit:     18415f19318fe277944953e2e1ec5ffcef125edf
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 15 21:08:41 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr 15 21:08:41 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=18415f19
15.0.0: update IPA-VRP vs LTO patch
From Honza at https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c37.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch | 394 +++++++++---------------
 1 file changed, 153 insertions(+), 241 deletions(-)
diff --git a/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch b/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
index 3049a2f..304b376 100644
--- a/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
+++ b/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
@@ -1,274 +1,186 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c32
-diff --git a/gcc/ipa-cp.cc b/gcc/ipa-cp.cc
-index 26b1496f29b..9b47c6c364d 100644
---- a/gcc/ipa-cp.cc
-+++ b/gcc/ipa-cp.cc
-@@ -6334,6 +6334,13 @@ ipcp_store_vr_results (void)
- 
-       if (info->ipcp_orig_node)
- 	info = ipa_node_params_sum->get (info->ipcp_orig_node);
-+
-+      if (do_vr && info->m_return_vr)
-+	{
-+	  clone_info *clone_info = clone_info::get_create (node);
-+	  clone_info->m_return_vr = info->m_return_vr;
-+	}
-+
-       if (info->lattices.is_empty ())
- 	/* Newly expanded artificial thunks do not have lattices.  */
- 	continue;
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c37
+
+	PR tree-optimization/119614
+
+gcc/ChangeLog:
+
+	* ipa-prop.cc (ipa_write_return_summaries): New function.
+	(ipa_record_return_value_range_1): Break out from ...
+	(ipa_record_return_value_range): ... here.
+	(ipa_read_return_summaries): New function.
+	(ipa_prop_read_section): Read return summaries.
+	(read_ipcp_transformation_info): Read return summaries.
+	(ipcp_write_transformation_summaries): write return summaries
+
+gcc/testsuite/ChangeLog:
+
+	* g++.dg/lto/pr119614_0.C: New test.
+
 diff --git a/gcc/ipa-prop.cc b/gcc/ipa-prop.cc
-index 49d68ab044b..eb757658ad7 100644
+index 49d68ab044b..4a83062bfcc 100644
 --- a/gcc/ipa-prop.cc
 +++ b/gcc/ipa-prop.cc
-@@ -2323,6 +2323,27 @@ ipa_get_value_range (const vrange &tmp)
-   return vr;
+@@ -5439,6 +5439,49 @@ ipa_read_node_info (class lto_input_block *ib, struct cgraph_node *node,
+     }
  }
  
-+/* Read an IPA-VR from IB and DATA_IN.  If it does not contain useful info,
-+   return nullptr.  If it is already in the hash of IPA-VRs, return the already
-+   present value, otherwise add it to the hash and return this new value.  */
-+
-+ipa_vr *
-+streamer_read_and_hash (lto_input_block *ib, data_in *data_in)
++/* Stream out ipa_return_summary.  */
++static void
++ipa_write_return_summaries (output_block *ob)
 +{
-+  ipa_vr ivr;
-+  ivr.streamer_read (ib, data_in);
-+  if (ivr.known_p ())
++  if (!ipa_return_value_sum)
 +    {
-+      if (!ipa_vr_hash_table)
-+	ipa_vr_hash_table = hash_table<ipa_vr_ggc_hash_traits>::create_ggc (37);
++      streamer_write_uhwi (ob, 0);
++      return;
++    }
 +
-+      value_range tmp;
-+      ivr.get_vrange (tmp);
-+      return ipa_get_value_range (tmp);
++  lto_symtab_encoder_t encoder = ob->decl_state->symtab_node_encoder;
++  unsigned int count = 0;
++  for (int i = 0; i < lto_symtab_encoder_size (encoder); i++)
++    {
++      symtab_node *snode = lto_symtab_encoder_deref (encoder, i);
++      cgraph_node *cnode = dyn_cast <cgraph_node *> (snode);
++      ipa_return_value_summary *v;
++
++      if (cnode && cnode->definition && !cnode->alias
++	  && (v = ipa_return_value_sum->get (cnode))
++	  && v->vr)
++	count++;
 +    }
-+  return nullptr;
-+}
++  streamer_write_uhwi (ob, count);
 +
- /* Assign to JF a pointer to a range just like TMP but either fetch a
-    copy from ipa_vr_hash_table or allocate a new on in GC memory.  */
- 
-@@ -3312,6 +3333,14 @@ ipa_analyze_node (struct cgraph_node *node)
-   analysis_dom_walker (&fbi).walk (ENTRY_BLOCK_PTR_FOR_FN (cfun));
-   disable_ranger (cfun);
- 
-+  ipa_return_value_summary *rvs;
++  for (int i = 0; i < lto_symtab_encoder_size (encoder); i++)
++    {
++      symtab_node *snode = lto_symtab_encoder_deref (encoder, i);
++      cgraph_node *cnode = dyn_cast <cgraph_node *> (snode);
++      ipa_return_value_summary *v;
 +
-+  if (ipa_return_value_sum
-+      && (rvs = ipa_return_value_sum->get (node)))
-+    /* The VRs in the summary already live in the cache, no need to go through
-+       ipa_get_value_range.  */
-+    info->m_return_vr = rvs->vr;
++      if (cnode && cnode->definition && !cnode->alias
++	  && (v = ipa_return_value_sum->get (cnode))
++	  && v->vr)
++	{
++	  streamer_write_uhwi
++	    (ob,
++	     lto_symtab_encoder_encode (encoder, cnode));
++	  v->vr->streamer_write (ob);
++	}
++    }
++}
 +
-   ipa_release_body_info (&fbi);
-   free_dominance_info (CDI_DOMINATORS);
-   pop_cfun ();
-@@ -4793,6 +4822,8 @@ ipa_node_params_t::duplicate(cgraph_node *, cgraph_node *,
-   new_info->known_csts = old_info->known_csts.copy ();
-   new_info->known_contexts = old_info->known_contexts.copy ();
+ /* Write jump functions for nodes in SET.  */
  
-+  new_info->m_return_vr = old_info->m_return_vr;
+ void
+@@ -5476,10 +5519,54 @@ ipa_prop_write_jump_functions (void)
+         ipa_write_node_info (ob, node);
+     }
+   streamer_write_char_stream (ob->main_stream, 0);
++  ipa_write_return_summaries (ob);
+   produce_asm (ob);
+   destroy_output_block (ob);
+ }
+ 
++/* Record that current function return value range is VAL.  */
 +
-   new_info->analysis_done = old_info->analysis_done;
-   new_info->node_enqueued = old_info->node_enqueued;
-   new_info->versionable = old_info->versionable;
-@@ -5272,6 +5303,15 @@ ipa_write_node_info (struct output_block *ob, struct cgraph_node *node)
-   streamer_write_uhwi (ob, ipa_get_param_count (info));
-   for (j = 0; j < ipa_get_param_count (info); j++)
-     streamer_write_uhwi (ob, ipa_get_param_move_cost (info, j));
-+  if (info->m_return_vr)
-+    info->m_return_vr->streamer_write (ob);
-+  else
++static void
++ipa_record_return_value_range_1 (cgraph_node *n, value_range val)
++{
++  if (!ipa_return_value_sum)
 +    {
-+      bp = bitpack_create (ob->main_stream);
-+      bp_pack_value (&bp, false, 1);
-+      streamer_write_bitpack (&bp);
++      if (!ipa_vr_hash_table)
++	ipa_vr_hash_table = hash_table<ipa_vr_ggc_hash_traits>::create_ggc (37);
++      ipa_return_value_sum = new (ggc_alloc_no_dtor <ipa_return_value_sum_t> ())
++	      ipa_return_value_sum_t (symtab, true);
++      ipa_return_value_sum->disable_insertion_hook ();
 +    }
-+
-   bp = bitpack_create (ob->main_stream);
-   gcc_assert (info->analysis_done
- 	      || ipa_get_param_count (info) == 0);
-@@ -5407,6 +5447,15 @@ ipa_read_node_info (class lto_input_block *ib, struct cgraph_node *node,
-     for (k = 0; k < param_count; k++)
-       streamer_read_uhwi (ib);
- 
-+  ipa_vr rvr;
-+  rvr.streamer_read (ib, data_in);
-+  if (prevails && rvr.known_p ())
++  ipa_return_value_sum->get_create (n)->vr = ipa_get_value_range (val);
++  if (dump_file && (dump_flags & TDF_DETAILS))
 +    {
-+      value_range tmp;
-+      rvr.get_vrange (tmp);
-+      info->m_return_vr = ipa_get_value_range (tmp);
++      fprintf (dump_file, "Recording return range ");
++      val.dump (dump_file);
++      fprintf (dump_file, "\n");
 +    }
++}
 +
-   bp = streamer_read_bitpack (ib);
-   for (k = 0; k < param_count; k++)
-     {
-@@ -6218,7 +6267,7 @@ bool
- ipa_return_value_range (value_range &range, tree decl)
- {
-   cgraph_node *n = cgraph_node::get (decl);
--  if (!n || !ipa_return_value_sum)
-+  if (!n)
-     return false;
-   enum availability avail;
-   n = n->ultimate_alias_target (&avail);
-@@ -6226,11 +6275,24 @@ ipa_return_value_range (value_range &range, tree decl)
-     return false;
-   if (n->decl != decl && !useless_type_conversion_p (TREE_TYPE (decl), TREE_TYPE (n->decl)))
-     return false;
--  ipa_return_value_summary *v = ipa_return_value_sum->get (n);
--  if (!v)
--    return false;
--  v->vr->get_vrange (range);
--  return true;
-+
-+  if (ipa_return_value_sum)
++/* Stream out ipa_return_summary.  */
++static void
++ipa_read_return_summaries (lto_input_block *ib,
++			   struct lto_file_decl_data *file_data,
++			   class data_in *data_in)
++{
++  unsigned int f_count = streamer_read_uhwi (ib);
++  for (unsigned int i = 0; i < f_count; i++)
 +    {
-+      if (ipa_return_value_summary *v = ipa_return_value_sum->get (n))
-+	{
-+	  v->vr->get_vrange (range);
-+	  return true;
-+	}
++      unsigned int index = streamer_read_uhwi (ib);
++      lto_symtab_encoder_t encoder = file_data->symtab_node_encoder;
++      struct cgraph_node *node = dyn_cast <cgraph_node *> (lto_symtab_encoder_deref (encoder,
++								index));
++      ipa_vr rvr;
++      rvr.streamer_read (ib, data_in);
++      value_range tmp;
++      rvr.get_vrange (tmp);
++      ipa_record_return_value_range_1 (node, tmp);
 +    }
++}
 +
-+  clone_info *info = clone_info::get (n);
-+  if (info && info->m_return_vr)
-+    {
-+      gcc_assert (info->m_return_vr->known_p ());
-+      info->m_return_vr->get_vrange (range);
-+      return true;
-+    }
-+  return false;
- }
+ /* Read section in file FILE_DATA of length LEN with data DATA.  */
  
- /* Reset all state within ipa-prop.cc so that we can rerun the compiler
-diff --git a/gcc/ipa-prop.h b/gcc/ipa-prop.h
-index 3bd442fff39..8dc8e2f2ab5 100644
---- a/gcc/ipa-prop.h
-+++ b/gcc/ipa-prop.h
-@@ -653,6 +653,9 @@ public:
-   /* If this node is an ipa-cp clone, these are the known polymorphic contexts
-      that describe what it has been specialized for.  */
-   vec<ipa_polymorphic_call_context> GTY((skip)) known_contexts;
-+  /* If non-NULL, the known value range of the return value of this
-+     function.  */
-+  class ipa_vr *m_return_vr;
-   /* Whether the param uses analysis and jump function computation has already
-      been performed.  */
-   unsigned analysis_done : 1;
-@@ -679,10 +682,10 @@ public:
- inline
- ipa_node_params::ipa_node_params ()
- : descriptors (NULL), lattices (vNULL), ipcp_orig_node (NULL),
--  known_csts (vNULL), known_contexts (vNULL), analysis_done (0),
--  node_enqueued (0), do_clone_for_all_contexts (0), is_all_contexts_clone (0),
--  node_dead (0), node_within_scc (0), node_is_self_scc (0),
--  node_calling_single_call (0), versionable (0)
-+  known_csts (vNULL), known_contexts (vNULL), m_return_vr (nullptr),
-+  analysis_done (0), node_enqueued (0), do_clone_for_all_contexts (0),
-+  is_all_contexts_clone (0), node_dead (0), node_within_scc (0),
-+  node_is_self_scc (0), node_calling_single_call (0), versionable (0)
- {
+ static void
+@@ -5516,6 +5603,7 @@ ipa_prop_read_section (struct lto_file_decl_data *file_data, const char *data,
+       gcc_assert (node->definition);
+       ipa_read_node_info (&ib_main, node, data_in);
+     }
++  ipa_read_return_summaries (&ib_main, file_data, data_in);
+   lto_free_section_data (file_data, LTO_section_jump_functions, NULL, data,
+ 			 len);
+   lto_data_in_delete (data_in);
+@@ -5635,6 +5723,7 @@ read_ipcp_transformation_info (lto_input_block *ib, cgraph_node *node,
+     }
  }
  
-@@ -1275,6 +1278,7 @@ bool unadjusted_ptr_and_unit_offset (tree op, tree *ret,
- 				     poly_int64 *offset_ret);
- void ipa_get_range_from_ip_invariant (vrange &r, tree val, cgraph_node *node);
- void ipa_prop_cc_finalize (void);
-+ipa_vr *streamer_read_and_hash (lto_input_block *ib, data_in *data_in);
- 
- /* From tree-sra.cc:  */
- tree build_ref_for_offset (location_t, tree, poly_int64, bool, tree,
-diff --git a/gcc/lto-cgraph.cc b/gcc/lto-cgraph.cc
-index ac835a435ec..a99e7227528 100644
---- a/gcc/lto-cgraph.cc
-+++ b/gcc/lto-cgraph.cc
-@@ -44,6 +44,11 @@ along with GCC; see the file COPYING3.  If not see
- #include "symbol-summary.h"
- #include "symtab-thunks.h"
- #include "symtab-clones.h"
-+#include "sreal.h"
-+#include "value-range.h"
-+#include "value-range-storage.h"
-+#include "ipa-cp.h"
-+#include "ipa-prop.h"
++
+ /* Write all aggregate replacement for nodes in set.  */
  
- /* True when asm nodes has been output.  */
- bool asm_nodes_output = false;
-@@ -1992,10 +1997,10 @@ input_offload_tables (bool do_force_output)
- static int
- output_cgraph_opt_summary_p (struct cgraph_node *node)
- {
--  if (node->clone_of || node->former_clone_of)
--    return true;
-   clone_info *info = clone_info::get (node);
--  return info && (info->tree_map || info->param_adjustments);
-+  return info && (info->tree_map
-+		  || info->param_adjustments
-+		  || info->m_return_vr);
+ void
+@@ -5674,6 +5763,7 @@ ipcp_write_transformation_summaries (void)
+ 	write_ipcp_transformation_info (ob, cnode, ts);
+     }
+   streamer_write_char_stream (ob->main_stream, 0);
++  ipa_write_return_summaries (ob);
+   produce_asm (ob);
+   destroy_output_block (ob);
  }
- 
- /* Output optimization summary for EDGE to OB.  */
-@@ -2065,6 +2070,15 @@ output_node_opt_summary (struct output_block *ob,
- 	stream_write_tree (ob, map->new_tree, true);
-       }
- 
-+  if (info && info->m_return_vr)
-+    info->m_return_vr->streamer_write (ob);
-+  else
-+    {
-+      bp = bitpack_create (ob->main_stream);
-+      bp_pack_value (&bp, false, 1);
-+      streamer_write_bitpack (&bp);
-+    }
-+
-   if (lto_symtab_encoder_in_partition_p (encoder, node))
-     {
-       for (e = node->callees; e; e = e->next_callee)
-@@ -2181,6 +2195,9 @@ input_node_opt_summary (struct cgraph_node *node,
-       map->parm_num = streamer_read_uhwi (ib_main);
-       map->new_tree = stream_read_tree (ib_main, data_in);
+@@ -5714,6 +5804,7 @@ read_replacements_section (struct lto_file_decl_data *file_data,
+ 								index));
+       read_ipcp_transformation_info (&ib_main, node, data_in);
      }
-+
-+  info->m_return_vr = streamer_read_and_hash (ib_main, data_in);
-+
-   for (e = node->callees; e; e = e->next_callee)
-     input_edge_opt_summary (e, ib_main);
-   for (e = node->indirect_calls; e; e = e->next_callee)
-diff --git a/gcc/symtab-clones.h b/gcc/symtab-clones.h
-index 362bcb63dd1..a63036fc94f 100644
---- a/gcc/symtab-clones.h
-+++ b/gcc/symtab-clones.h
-@@ -21,12 +21,15 @@ along with GCC; see the file COPYING3.  If not see
- #ifndef GCC_SYMTAB_CLONES_H
- #define GCC_SYMTAB_CLONES_H
- 
-+class ipa_vr;
-+
- struct GTY(()) clone_info
++  ipa_read_return_summaries (&ib_main, file_data, data_in);
+   lto_free_section_data (file_data, LTO_section_jump_functions, NULL, data,
+ 			 len);
+   lto_data_in_delete (data_in);
+@@ -6194,22 +6285,7 @@ ipcp_transform_function (struct cgraph_node *node)
+ void
+ ipa_record_return_value_range (value_range val)
  {
-   /* Constructor.  */
-   clone_info ()
-     : tree_map (NULL),
--      param_adjustments (NULL)
-+      param_adjustments (NULL),
-+      m_return_vr (nullptr)
-   {
-   }
-   /* Constants discovered by IPA-CP, i.e. which parameter should be replaced
-@@ -35,6 +38,10 @@ struct GTY(()) clone_info
-   /* Parameter modification that IPA-SRA decided to perform.  */
-   ipa_param_adjustments *param_adjustments;
- 
-+  /* If non-NULL, the known value range of the return value of this
-+     function.  */
-+  ipa_vr *m_return_vr;
-+
-   /* Return clone_info, if available.  */
-   static clone_info *get (cgraph_node *node);
+-  cgraph_node *n = cgraph_node::get (current_function_decl);
+-  if (!ipa_return_value_sum)
+-    {
+-      if (!ipa_vr_hash_table)
+-	ipa_vr_hash_table = hash_table<ipa_vr_ggc_hash_traits>::create_ggc (37);
+-      ipa_return_value_sum = new (ggc_alloc_no_dtor <ipa_return_value_sum_t> ())
+-	      ipa_return_value_sum_t (symtab, true);
+-      ipa_return_value_sum->disable_insertion_hook ();
+-    }
+-  ipa_return_value_sum->get_create (n)->vr = ipa_get_value_range (val);
+-  if (dump_file && (dump_flags & TDF_DETAILS))
+-    {
+-      fprintf (dump_file, "Recording return range ");
+-      val.dump (dump_file);
+-      fprintf (dump_file, "\n");
+-    }
++  ipa_record_return_value_range_1 (cgraph_node::get (current_function_decl), val);
+ }
  
+ /* Return true if value range of DECL is known and if so initialize RANGE.  */
 diff --git a/gcc/testsuite/g++.dg/lto/pr119614_0.C b/gcc/testsuite/g++.dg/lto/pr119614_0.C
 new file mode 100644
 index 00000000000..09c07fbf566
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-16  9:58 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-16  9:58 UTC (permalink / raw
  To: gentoo-commits
commit:     cc3f74893c9108e231137e8cc94f1332ea149b1f
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 16 09:58:22 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 16 09:58:46 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=cc3f7489
15.0.0: update 85_all_PR119614-ipa-vrp-lto.patch
(with debug prints commented out)
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch | 21 ++++++++++++++-------
 1 file changed, 14 insertions(+), 7 deletions(-)
diff --git a/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch b/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
index 304b376..01419b6 100644
--- a/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
+++ b/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
@@ -1,4 +1,5 @@
 https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c37
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c46
 
 	PR tree-optimization/119614
 
@@ -16,8 +17,10 @@ gcc/testsuite/ChangeLog:
 
 	* g++.dg/lto/pr119614_0.C: New test.
 
+
+
 diff --git a/gcc/ipa-prop.cc b/gcc/ipa-prop.cc
-index 49d68ab044b..4a83062bfcc 100644
+index 49d68ab044b..f959458ca1e 100644
 --- a/gcc/ipa-prop.cc
 +++ b/gcc/ipa-prop.cc
 @@ -5439,6 +5439,49 @@ ipa_read_node_info (class lto_input_block *ib, struct cgraph_node *node,
@@ -70,10 +73,11 @@ index 49d68ab044b..4a83062bfcc 100644
  /* Write jump functions for nodes in SET.  */
  
  void
-@@ -5476,10 +5519,54 @@ ipa_prop_write_jump_functions (void)
+@@ -5475,11 +5518,56 @@ ipa_prop_write_jump_functions (void)
+ 	  && ipa_node_params_sum->get (node) != NULL)
          ipa_write_node_info (ob, node);
      }
-   streamer_write_char_stream (ob->main_stream, 0);
+-  streamer_write_char_stream (ob->main_stream, 0);
 +  ipa_write_return_summaries (ob);
    produce_asm (ob);
    destroy_output_block (ob);
@@ -108,6 +112,7 @@ index 49d68ab044b..4a83062bfcc 100644
 +			   class data_in *data_in)
 +{
 +  unsigned int f_count = streamer_read_uhwi (ib);
++  //fprintf (stderr, "reading %i:\n", f_count);
 +  for (unsigned int i = 0; i < f_count; i++)
 +    {
 +      unsigned int index = streamer_read_uhwi (ib);
@@ -116,6 +121,7 @@ index 49d68ab044b..4a83062bfcc 100644
 +								index));
 +      ipa_vr rvr;
 +      rvr.streamer_read (ib, data_in);
++      //rvr.dump (stderr);
 +      value_range tmp;
 +      rvr.get_vrange (tmp);
 +      ipa_record_return_value_range_1 (node, tmp);
@@ -125,7 +131,7 @@ index 49d68ab044b..4a83062bfcc 100644
  /* Read section in file FILE_DATA of length LEN with data DATA.  */
  
  static void
-@@ -5516,6 +5603,7 @@ ipa_prop_read_section (struct lto_file_decl_data *file_data, const char *data,
+@@ -5516,6 +5604,7 @@ ipa_prop_read_section (struct lto_file_decl_data *file_data, const char *data,
        gcc_assert (node->definition);
        ipa_read_node_info (&ib_main, node, data_in);
      }
@@ -133,7 +139,7 @@ index 49d68ab044b..4a83062bfcc 100644
    lto_free_section_data (file_data, LTO_section_jump_functions, NULL, data,
  			 len);
    lto_data_in_delete (data_in);
-@@ -5635,6 +5723,7 @@ read_ipcp_transformation_info (lto_input_block *ib, cgraph_node *node,
+@@ -5635,6 +5724,7 @@ read_ipcp_transformation_info (lto_input_block *ib, cgraph_node *node,
      }
  }
  
@@ -141,10 +147,11 @@ index 49d68ab044b..4a83062bfcc 100644
  /* Write all aggregate replacement for nodes in set.  */
  
  void
-@@ -5674,6 +5763,7 @@ ipcp_write_transformation_summaries (void)
+@@ -5673,7 +5763,7 @@ ipcp_write_transformation_summaries (void)
+ 	  && lto_symtab_encoder_encode_body_p (encoder, cnode))
  	write_ipcp_transformation_info (ob, cnode, ts);
      }
-   streamer_write_char_stream (ob->main_stream, 0);
+-  streamer_write_char_stream (ob->main_stream, 0);
 +  ipa_write_return_summaries (ob);
    produce_asm (ob);
    destroy_output_block (ob);
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-16 10:04 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-16 10:04 UTC (permalink / raw
  To: gentoo-commits
commit:     fff7c4338996aca1b0fc78e9ec5ea74772430c94
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 16 10:03:50 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 16 10:04:16 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=fff7c433
15.0.0: update 85_all_PR119614-ipa-vrp-lto.patch (trivial)
Just use Honza's version w/o debug prints, but it's the same.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch | 36 +++++++++++--------------
 1 file changed, 16 insertions(+), 20 deletions(-)
diff --git a/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch b/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
index 01419b6..0f9b0c9 100644
--- a/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
+++ b/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
@@ -1,26 +1,24 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c37
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c46
+https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c47
 
 	PR tree-optimization/119614
 
 gcc/ChangeLog:
 
-	* ipa-prop.cc (ipa_write_return_summaries): New function.
-	(ipa_record_return_value_range_1): Break out from ...
-	(ipa_record_return_value_range): ... here.
-	(ipa_read_return_summaries): New function.
-	(ipa_prop_read_section): Read return summaries.
-	(read_ipcp_transformation_info): Read return summaries.
-	(ipcp_write_transformation_summaries): write return summaries
+	* ipa-prop.cc (ipa_write_return_summaries):
+	(ipa_record_return_value_range_1):
+	(ipa_read_return_summaries):
+	(ipa_prop_read_section):
+	(read_ipcp_transformation_info):
+	(ipcp_write_transformation_summaries):
+	(read_replacements_section):
+	(ipa_record_return_value_range):
 
 gcc/testsuite/ChangeLog:
 
 	* g++.dg/lto/pr119614_0.C: New test.
 
-
-
 diff --git a/gcc/ipa-prop.cc b/gcc/ipa-prop.cc
-index 49d68ab044b..f959458ca1e 100644
+index 49d68ab044b..7b50c4fc31f 100644
 --- a/gcc/ipa-prop.cc
 +++ b/gcc/ipa-prop.cc
 @@ -5439,6 +5439,49 @@ ipa_read_node_info (class lto_input_block *ib, struct cgraph_node *node,
@@ -73,7 +71,7 @@ index 49d68ab044b..f959458ca1e 100644
  /* Write jump functions for nodes in SET.  */
  
  void
-@@ -5475,11 +5518,56 @@ ipa_prop_write_jump_functions (void)
+@@ -5475,11 +5518,54 @@ ipa_prop_write_jump_functions (void)
  	  && ipa_node_params_sum->get (node) != NULL)
          ipa_write_node_info (ob, node);
      }
@@ -112,7 +110,6 @@ index 49d68ab044b..f959458ca1e 100644
 +			   class data_in *data_in)
 +{
 +  unsigned int f_count = streamer_read_uhwi (ib);
-+  //fprintf (stderr, "reading %i:\n", f_count);
 +  for (unsigned int i = 0; i < f_count; i++)
 +    {
 +      unsigned int index = streamer_read_uhwi (ib);
@@ -121,7 +118,6 @@ index 49d68ab044b..f959458ca1e 100644
 +								index));
 +      ipa_vr rvr;
 +      rvr.streamer_read (ib, data_in);
-+      //rvr.dump (stderr);
 +      value_range tmp;
 +      rvr.get_vrange (tmp);
 +      ipa_record_return_value_range_1 (node, tmp);
@@ -131,7 +127,7 @@ index 49d68ab044b..f959458ca1e 100644
  /* Read section in file FILE_DATA of length LEN with data DATA.  */
  
  static void
-@@ -5516,6 +5604,7 @@ ipa_prop_read_section (struct lto_file_decl_data *file_data, const char *data,
+@@ -5516,6 +5602,7 @@ ipa_prop_read_section (struct lto_file_decl_data *file_data, const char *data,
        gcc_assert (node->definition);
        ipa_read_node_info (&ib_main, node, data_in);
      }
@@ -139,7 +135,7 @@ index 49d68ab044b..f959458ca1e 100644
    lto_free_section_data (file_data, LTO_section_jump_functions, NULL, data,
  			 len);
    lto_data_in_delete (data_in);
-@@ -5635,6 +5724,7 @@ read_ipcp_transformation_info (lto_input_block *ib, cgraph_node *node,
+@@ -5635,6 +5722,7 @@ read_ipcp_transformation_info (lto_input_block *ib, cgraph_node *node,
      }
  }
  
@@ -147,7 +143,7 @@ index 49d68ab044b..f959458ca1e 100644
  /* Write all aggregate replacement for nodes in set.  */
  
  void
-@@ -5673,7 +5763,7 @@ ipcp_write_transformation_summaries (void)
+@@ -5673,7 +5761,7 @@ ipcp_write_transformation_summaries (void)
  	  && lto_symtab_encoder_encode_body_p (encoder, cnode))
  	write_ipcp_transformation_info (ob, cnode, ts);
      }
@@ -156,7 +152,7 @@ index 49d68ab044b..f959458ca1e 100644
    produce_asm (ob);
    destroy_output_block (ob);
  }
-@@ -5714,6 +5804,7 @@ read_replacements_section (struct lto_file_decl_data *file_data,
+@@ -5714,6 +5802,7 @@ read_replacements_section (struct lto_file_decl_data *file_data,
  								index));
        read_ipcp_transformation_info (&ib_main, node, data_in);
      }
@@ -164,7 +160,7 @@ index 49d68ab044b..f959458ca1e 100644
    lto_free_section_data (file_data, LTO_section_jump_functions, NULL, data,
  			 len);
    lto_data_in_delete (data_in);
-@@ -6194,22 +6285,7 @@ ipcp_transform_function (struct cgraph_node *node)
+@@ -6194,22 +6283,7 @@ ipcp_transform_function (struct cgraph_node *node)
  void
  ipa_record_return_value_range (value_range val)
  {
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-16 13:30 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-16 13:30 UTC (permalink / raw
  To: gentoo-commits
commit:     9d237724dba71ae461284d7e4c36db94cb35112f
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 16 13:30:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 16 13:30:23 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=9d237724
15.0.0: drop now-upstream IPA-VRP patch
\o/
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch | 226 ------------------------
 15.0.0/gentoo/README.history                    |   1 -
 2 files changed, 227 deletions(-)
diff --git a/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch b/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
deleted file mode 100644
index 0f9b0c9..0000000
--- a/15.0.0/gentoo/85_all_PR119614-ipa-vrp-lto.patch
+++ /dev/null
@@ -1,226 +0,0 @@
-https://gcc.gnu.org/bugzilla/show_bug.cgi?id=119614#c47
-
-	PR tree-optimization/119614
-
-gcc/ChangeLog:
-
-	* ipa-prop.cc (ipa_write_return_summaries):
-	(ipa_record_return_value_range_1):
-	(ipa_read_return_summaries):
-	(ipa_prop_read_section):
-	(read_ipcp_transformation_info):
-	(ipcp_write_transformation_summaries):
-	(read_replacements_section):
-	(ipa_record_return_value_range):
-
-gcc/testsuite/ChangeLog:
-
-	* g++.dg/lto/pr119614_0.C: New test.
-
-diff --git a/gcc/ipa-prop.cc b/gcc/ipa-prop.cc
-index 49d68ab044b..7b50c4fc31f 100644
---- a/gcc/ipa-prop.cc
-+++ b/gcc/ipa-prop.cc
-@@ -5439,6 +5439,49 @@ ipa_read_node_info (class lto_input_block *ib, struct cgraph_node *node,
-     }
- }
- 
-+/* Stream out ipa_return_summary.  */
-+static void
-+ipa_write_return_summaries (output_block *ob)
-+{
-+  if (!ipa_return_value_sum)
-+    {
-+      streamer_write_uhwi (ob, 0);
-+      return;
-+    }
-+
-+  lto_symtab_encoder_t encoder = ob->decl_state->symtab_node_encoder;
-+  unsigned int count = 0;
-+  for (int i = 0; i < lto_symtab_encoder_size (encoder); i++)
-+    {
-+      symtab_node *snode = lto_symtab_encoder_deref (encoder, i);
-+      cgraph_node *cnode = dyn_cast <cgraph_node *> (snode);
-+      ipa_return_value_summary *v;
-+
-+      if (cnode && cnode->definition && !cnode->alias
-+	  && (v = ipa_return_value_sum->get (cnode))
-+	  && v->vr)
-+	count++;
-+    }
-+  streamer_write_uhwi (ob, count);
-+
-+  for (int i = 0; i < lto_symtab_encoder_size (encoder); i++)
-+    {
-+      symtab_node *snode = lto_symtab_encoder_deref (encoder, i);
-+      cgraph_node *cnode = dyn_cast <cgraph_node *> (snode);
-+      ipa_return_value_summary *v;
-+
-+      if (cnode && cnode->definition && !cnode->alias
-+	  && (v = ipa_return_value_sum->get (cnode))
-+	  && v->vr)
-+	{
-+	  streamer_write_uhwi
-+	    (ob,
-+	     lto_symtab_encoder_encode (encoder, cnode));
-+	  v->vr->streamer_write (ob);
-+	}
-+    }
-+}
-+
- /* Write jump functions for nodes in SET.  */
- 
- void
-@@ -5475,11 +5518,54 @@ ipa_prop_write_jump_functions (void)
- 	  && ipa_node_params_sum->get (node) != NULL)
-         ipa_write_node_info (ob, node);
-     }
--  streamer_write_char_stream (ob->main_stream, 0);
-+  ipa_write_return_summaries (ob);
-   produce_asm (ob);
-   destroy_output_block (ob);
- }
- 
-+/* Record that current function return value range is VAL.  */
-+
-+static void
-+ipa_record_return_value_range_1 (cgraph_node *n, value_range val)
-+{
-+  if (!ipa_return_value_sum)
-+    {
-+      if (!ipa_vr_hash_table)
-+	ipa_vr_hash_table = hash_table<ipa_vr_ggc_hash_traits>::create_ggc (37);
-+      ipa_return_value_sum = new (ggc_alloc_no_dtor <ipa_return_value_sum_t> ())
-+	      ipa_return_value_sum_t (symtab, true);
-+      ipa_return_value_sum->disable_insertion_hook ();
-+    }
-+  ipa_return_value_sum->get_create (n)->vr = ipa_get_value_range (val);
-+  if (dump_file && (dump_flags & TDF_DETAILS))
-+    {
-+      fprintf (dump_file, "Recording return range ");
-+      val.dump (dump_file);
-+      fprintf (dump_file, "\n");
-+    }
-+}
-+
-+/* Stream out ipa_return_summary.  */
-+static void
-+ipa_read_return_summaries (lto_input_block *ib,
-+			   struct lto_file_decl_data *file_data,
-+			   class data_in *data_in)
-+{
-+  unsigned int f_count = streamer_read_uhwi (ib);
-+  for (unsigned int i = 0; i < f_count; i++)
-+    {
-+      unsigned int index = streamer_read_uhwi (ib);
-+      lto_symtab_encoder_t encoder = file_data->symtab_node_encoder;
-+      struct cgraph_node *node = dyn_cast <cgraph_node *> (lto_symtab_encoder_deref (encoder,
-+								index));
-+      ipa_vr rvr;
-+      rvr.streamer_read (ib, data_in);
-+      value_range tmp;
-+      rvr.get_vrange (tmp);
-+      ipa_record_return_value_range_1 (node, tmp);
-+    }
-+}
-+
- /* Read section in file FILE_DATA of length LEN with data DATA.  */
- 
- static void
-@@ -5516,6 +5602,7 @@ ipa_prop_read_section (struct lto_file_decl_data *file_data, const char *data,
-       gcc_assert (node->definition);
-       ipa_read_node_info (&ib_main, node, data_in);
-     }
-+  ipa_read_return_summaries (&ib_main, file_data, data_in);
-   lto_free_section_data (file_data, LTO_section_jump_functions, NULL, data,
- 			 len);
-   lto_data_in_delete (data_in);
-@@ -5635,6 +5722,7 @@ read_ipcp_transformation_info (lto_input_block *ib, cgraph_node *node,
-     }
- }
- 
-+
- /* Write all aggregate replacement for nodes in set.  */
- 
- void
-@@ -5673,7 +5761,7 @@ ipcp_write_transformation_summaries (void)
- 	  && lto_symtab_encoder_encode_body_p (encoder, cnode))
- 	write_ipcp_transformation_info (ob, cnode, ts);
-     }
--  streamer_write_char_stream (ob->main_stream, 0);
-+  ipa_write_return_summaries (ob);
-   produce_asm (ob);
-   destroy_output_block (ob);
- }
-@@ -5714,6 +5802,7 @@ read_replacements_section (struct lto_file_decl_data *file_data,
- 								index));
-       read_ipcp_transformation_info (&ib_main, node, data_in);
-     }
-+  ipa_read_return_summaries (&ib_main, file_data, data_in);
-   lto_free_section_data (file_data, LTO_section_jump_functions, NULL, data,
- 			 len);
-   lto_data_in_delete (data_in);
-@@ -6194,22 +6283,7 @@ ipcp_transform_function (struct cgraph_node *node)
- void
- ipa_record_return_value_range (value_range val)
- {
--  cgraph_node *n = cgraph_node::get (current_function_decl);
--  if (!ipa_return_value_sum)
--    {
--      if (!ipa_vr_hash_table)
--	ipa_vr_hash_table = hash_table<ipa_vr_ggc_hash_traits>::create_ggc (37);
--      ipa_return_value_sum = new (ggc_alloc_no_dtor <ipa_return_value_sum_t> ())
--	      ipa_return_value_sum_t (symtab, true);
--      ipa_return_value_sum->disable_insertion_hook ();
--    }
--  ipa_return_value_sum->get_create (n)->vr = ipa_get_value_range (val);
--  if (dump_file && (dump_flags & TDF_DETAILS))
--    {
--      fprintf (dump_file, "Recording return range ");
--      val.dump (dump_file);
--      fprintf (dump_file, "\n");
--    }
-+  ipa_record_return_value_range_1 (cgraph_node::get (current_function_decl), val);
- }
- 
- /* Return true if value range of DECL is known and if so initialize RANGE.  */
-diff --git a/gcc/testsuite/g++.dg/lto/pr119614_0.C b/gcc/testsuite/g++.dg/lto/pr119614_0.C
-new file mode 100644
-index 00000000000..09c07fbf566
---- /dev/null
-+++ b/gcc/testsuite/g++.dg/lto/pr119614_0.C
-@@ -0,0 +1,34 @@
-+// PR tree-optimization/119614
-+// { dg-lto-do link }
-+// { dg-lto-options { { -O2 -fPIC -flto -flto-partition=max } } }
-+// { dg-require-effective-target shared }
-+// { dg-require-effective-target fpic }
-+// { dg-require-effective-target musttail }
-+// { dg-extra-ld-options "-shared" }
-+
-+struct S {} b;
-+char *foo ();
-+int e, g;
-+void bar ();
-+void corge (S);
-+
-+[[gnu::noinline]] static char *
-+baz ()
-+{
-+  bar ();
-+  return 0;
-+}
-+
-+const char *
-+qux ()
-+{
-+  if (e)
-+    {
-+      S a = b;
-+      corge (a);
-+      if (g)
-+        return 0;
-+      [[gnu::musttail]] return baz ();
-+    }
-+  return foo ();
-+}
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 35249b2..678df05 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -3,7 +3,6 @@
 	- 82_all_PR119318-ipa-cp.patch
 	- 84_all_PR116975.patch
 	+ 84_all_PR116975-GDCFLAGS.patch
-	+ 85_all_PR119614-ipa-vrp-lto.patch
 
 54	13 April 2025
 
^ permalink raw reply related	[flat|nested] 227+ messages in thread
* [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/
@ 2025-04-18 19:21 Sam James
  0 siblings, 0 replies; 227+ messages in thread
From: Sam James @ 2025-04-18 19:21 UTC (permalink / raw
  To: gentoo-commits
commit:     ed2c4335a1f3f67a777acf76fb36fd50aa25afe0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Apr 18 19:20:49 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Apr 18 19:20:49 2025 +0000
URL:        https://gitweb.gentoo.org/proj/gcc-patches.git/commit/?id=ed2c4335
15.0.0: cut patchset 55
Signed-off-by: Sam James <sam <AT> gentoo.org>
 15.0.0/gentoo/README.history | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/15.0.0/gentoo/README.history b/15.0.0/gentoo/README.history
index 678df05..b29f28e 100644
--- a/15.0.0/gentoo/README.history
+++ b/15.0.0/gentoo/README.history
@@ -1,4 +1,4 @@
-55	????
+55	18 April 2025
 
 	- 82_all_PR119318-ipa-cp.patch
 	- 84_all_PR116975.patch
^ permalink raw reply related	[flat|nested] 227+ messages in thread
end of thread, other threads:[~2025-04-18 19:21 UTC | newest]
Thread overview: 227+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-01-06  4:44 [gentoo-commits] proj/gcc-patches:master commit in: 15.0.0/gentoo/ Sam James
  -- strict thread matches above, loose matches on Subject: below --
2025-04-18 19:21 Sam James
2025-04-16 13:30 Sam James
2025-04-16 10:04 Sam James
2025-04-16  9:58 Sam James
2025-04-15 21:09 Sam James
2025-04-15 16:40 Sam James
2025-04-14 22:59 Sam James
2025-04-14 22:47 Sam James
2025-04-14 22:44 Sam James
2025-04-14 21:06 Sam James
2025-04-14 20:51 Sam James
2025-04-14 16:08 Sam James
2025-04-14 16:08 Sam James
2025-04-13 22:54 Sam James
2025-04-10 21:59 Sam James
2025-04-10  9:08 Sam James
2025-04-09 15:27 Sam James
2025-04-09 13:27 Sam James
2025-04-09 12:42 Sam James
2025-04-07 18:02 Sam James
2025-04-07  7:07 Sam James
2025-04-07  6:54 Sam James
2025-04-06 23:08 Sam James
2025-04-05 15:33 Sam James
2025-04-05  8:02 Sam James
2025-04-05  1:43 Sam James
2025-04-04 19:06 Sam James
2025-04-02 18:48 Sam James
2025-04-02 18:03 Sam James
2025-04-02 16:14 Sam James
2025-04-02 13:56 Sam James
2025-04-02  4:59 Sam James
2025-04-01 14:46 Sam James
2025-04-01 14:46 Sam James
2025-03-31 22:16 Sam James
2025-03-31 22:03 Sam James
2025-03-31  4:05 Sam James
2025-03-29 20:31 Sam James
2025-03-29 14:33 Sam James
2025-03-29 13:51 Sam James
2025-03-26  6:25 Sam James
2025-03-25 10:27 Sam James
2025-03-25  8:38 Sam James
2025-03-25  2:32 Sam James
2025-03-25  1:27 Sam James
2025-03-24  0:35 Sam James
2025-03-21 19:31 Sam James
2025-03-21 17:21 Sam James
2025-03-21 16:23 Sam James
2025-03-21 11:20 Sam James
2025-03-21  8:51 Sam James
2025-03-21  6:07 Sam James
2025-03-20 22:08 Sam James
2025-03-20  1:59 Sam James
2025-03-20  1:59 Sam James
2025-03-16 22:37 Sam James
2025-03-14 14:46 Sam James
2025-03-14 13:37 Sam James
2025-03-13 16:48 Sam James
2025-03-13 10:08 Sam James
2025-03-11 10:32 Sam James
2025-03-07 16:54 Sam James
2025-03-03 16:38 Sam James
2025-03-01 10:33 Sam James
2025-03-01  6:50 Sam James
2025-02-17  1:30 Sam James
2025-02-13  9:23 Sam James
2025-02-12 15:12 Sam James
2025-02-10 21:22 Sam James
2025-02-09 23:58 Sam James
2025-02-07 23:37 Sam James
2025-02-07 21:19 Sam James
2025-02-03 22:04 Sam James
2025-02-02 22:41 Sam James
2025-01-29 20:21 Sam James
2025-01-26 22:52 Sam James
2025-01-22 16:27 Sam James
2025-01-19 22:43 Sam James
2025-01-16 23:11 Sam James
2025-01-16 23:11 Sam James
2025-01-15 11:41 Sam James
2025-01-14 16:22 Sam James
2025-01-14 15:06 Sam James
2025-01-14 15:06 Sam James
2025-01-14 12:29 Sam James
2025-01-14  8:43 Sam James
2025-01-14  8:40 Sam James
2025-01-13 13:58 Sam James
2025-01-13  6:00 Sam James
2025-01-13  3:40 Sam James
2025-01-13  3:23 Sam James
2025-01-13  3:20 Sam James
2025-01-13  0:20 Sam James
2025-01-12 18:53 Sam James
2025-01-11 12:53 Sam James
2025-01-08 21:51 Sam James
2025-01-06 10:50 Sam James
2025-01-06 10:03 Sam James
2025-01-06  4:49 Sam James
2025-01-06  4:13 Sam James
2025-01-06  4:13 Sam James
2025-01-06  4:13 Sam James
2025-01-06  4:03 Sam James
2025-01-05 23:19 Sam James
2025-01-03  3:07 Sam James
2024-12-30  1:05 Sam James
2024-12-29 10:00 Sam James
2024-12-27 15:14 Sam James
2024-12-27 15:14 Sam James
2024-12-24 20:48 Sam James
2024-12-22 22:46 Sam James
2024-12-20 11:25 Sam James
2024-12-20  5:57 Sam James
2024-12-20  1:55 Sam James
2024-12-19 18:34 Sam James
2024-12-16 15:14 Sam James
2024-12-13 13:23 Sam James
2024-12-13 11:52 Sam James
2024-12-13  5:08 Sam James
2024-12-12 12:28 Sam James
2024-12-11  4:41 Sam James
2024-12-11  0:58 Sam James
2024-12-10 19:19 Sam James
2024-12-10 14:55 Sam James
2024-12-10  5:19 Sam James
2024-12-10  5:13 Sam James
2024-12-10  5:11 Sam James
2024-12-10  5:07 Sam James
2024-12-09  3:05 Sam James
2024-12-08 22:41 Sam James
2024-12-06 17:33 Sam James
2024-12-04 20:40 Sam James
2024-12-01 22:51 Sam James
2024-12-01 22:51 Sam James
2024-11-30 11:30 Sam James
2024-11-30 11:04 Sam James
2024-11-27 17:42 Sam James
2024-11-25 15:10 Sam James
2024-11-25  3:01 Sam James
2024-11-25  3:00 Sam James
2024-11-25  3:00 Sam James
2024-11-24 22:42 Sam James
2024-11-18 17:25 Sam James
2024-11-18 10:42 Sam James
2024-11-18 10:42 Sam James
2024-11-18  9:25 Sam James
2024-11-18  9:25 Sam James
2024-11-14 18:38 Sam James
2024-11-13  4:26 Sam James
2024-11-13  0:16 Sam James
2024-11-12  2:33 Sam James
2024-11-11 19:46 Sam James
2024-11-11 19:46 Sam James
2024-11-10 22:41 Sam James
2024-11-09 16:24 Sam James
2024-11-09  7:55 Sam James
2024-11-08  8:22 Sam James
2024-11-07 16:13 Sam James
2024-11-03 23:16 Sam James
2024-11-01  8:24 Sam James
2024-11-01  8:24 Sam James
2024-11-01  8:18 Sam James
2024-11-01  8:17 Sam James
2024-10-30 16:03 Sam James
2024-10-29 19:17 Sam James
2024-10-28 21:32 Sam James
2024-10-28  8:09 Sam James
2024-10-23 15:40 Sam James
2024-10-22 19:09 Sam James
2024-10-22 18:34 Sam James
2024-10-21 12:33 Sam James
2024-10-21 12:27 Sam James
2024-10-21 12:26 Sam James
2024-10-21 11:45 Sam James
2024-10-20 22:42 Sam James
2024-10-18 14:05 Sam James
2024-10-18 10:35 Sam James
2024-10-17 23:33 Sam James
2024-10-17 23:03 Sam James
2024-10-17  5:01 Sam James
2024-10-17  4:15 Sam James
2024-10-13 22:48 Sam James
2024-10-07  2:45 Sam James
2024-10-04 10:37 Sam James
2024-10-04  9:28 Sam James
2024-10-02 19:45 Sam James
2024-09-30 14:05 Sam James
2024-09-29 22:56 Sam James
2024-09-24  1:41 Sam James
2024-09-23 15:23 Sam James
2024-09-02  2:28 Sam James
2024-08-26 13:44 Sam James
2024-08-26  6:24 Sam James
2024-08-23 13:51 Sam James
2024-08-20 20:31 Sam James
2024-08-19 18:43 Sam James
2024-08-14  9:48 Sam James
2024-08-14  2:57 Sam James
2024-08-11 22:40 Sam James
2024-08-09 19:54 Sam James
2024-08-09 19:54 Sam James
2024-08-09 19:47 Sam James
2024-08-09 19:25 Sam James
2024-08-08 11:10 Sam James
2024-08-08 11:06 Sam James
2024-08-08 11:03 Sam James
2024-08-05  9:09 Sam James
2024-08-05  1:54 Sam James
2024-08-05  1:51 Sam James
2024-08-02 20:39 Sam James
2024-08-01 14:40 Sam James
2024-07-28 23:34 Sam James
2024-07-22  1:11 Sam James
2024-07-19 11:14 Sam James
2024-07-18  0:45 Sam James
2024-07-14 23:36 Sam James
2024-06-28 12:49 Sam James
2024-06-27  0:02 Sam James
2024-06-26 23:57 Sam James
2024-06-16 22:45 Sam James
2024-06-10 20:18 Sam James
2024-06-10 17:28 Sam James
2024-06-10 17:28 Sam James
2024-06-10  2:08 Sam James
2024-06-08 17:03 Sam James
2024-06-08 17:03 Sam James
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox