]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
tree-optimization/123602 - avoid PRE-inserting abnormal SSA refs
authorRichard Biener <rguenther@suse.de>
Mon, 19 Jan 2026 09:21:10 +0000 (10:21 +0100)
committerRichard Biener <rguenth@gcc.gnu.org>
Mon, 19 Jan 2026 10:37:57 +0000 (11:37 +0100)
The following fixes an omission in find_or_generate_expression to
check for SSA_NAME_OCCURS_IN_ABNORMAL_PHI as already done in
create_expression_by_pieces.

PR tree-optimization/123602
* tree-ssa-pre.cc (find_or_generate_expression): Do not
generate references to abnormal SSA names.

* g++.dg/torture/pr123603.C: New testcase.

gcc/testsuite/g++.dg/torture/pr123603.C [new file with mode: 0644]
gcc/tree-ssa-pre.cc

diff --git a/gcc/testsuite/g++.dg/torture/pr123603.C b/gcc/testsuite/g++.dg/torture/pr123603.C
new file mode 100644 (file)
index 0000000..f971a82
--- /dev/null
@@ -0,0 +1,20 @@
+// { dg-do compile }
+
+void _setjmp();
+void a() __attribute__((__noreturn__));
+struct b {
+  b(int c) {
+    if (c)
+      a();
+  }
+  ~b();
+};
+int d;
+void l(long);
+void e() {
+  b a(d);
+  for (int f = 0; f < 10 ; ++f) {
+    l(f - 1);
+    _setjmp();
+  }
+}
index 9853be167d4a0e1bfdf3a62e96c855849532bb65..6a5f1287fac83627f194d2ac5011a2907ab0ecf6 100644 (file)
@@ -2768,7 +2768,12 @@ find_or_generate_expression (basic_block block, tree op, gimple_seq *stmts)
   if (leader)
     {
       if (leader->kind == NAME)
-       return PRE_EXPR_NAME (leader);
+       {
+         tree name = PRE_EXPR_NAME (leader);
+         if (SSA_NAME_OCCURS_IN_ABNORMAL_PHI (name))
+           return NULL_TREE;
+         return name;
+       }
       else if (leader->kind == CONSTANT)
        return PRE_EXPR_CONSTANT (leader);