The following fixes the test for an exit edge I put in place for
the fix for PR45178 where I somehow misunderstood how the cyclic
list works.

Bootstrapped and tested on x86_64-unknown-linux-gnu, pushed.

2021-10-22  Richard Biener  <rguent...@suse.de>

        PR tree-optimization/102893
        * tree-ssa-dce.c (find_obviously_necessary_stmts): Fix the
        test for an exit edge.

        * gcc.dg/tree-ssa/ssa-dce-9.c: New testcase.
---
 gcc/testsuite/gcc.dg/tree-ssa/ssa-dce-9.c | 10 ++++++++++
 gcc/tree-ssa-dce.c                        |  2 +-
 2 files changed, 11 insertions(+), 1 deletion(-)
 create mode 100644 gcc/testsuite/gcc.dg/tree-ssa/ssa-dce-9.c

diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dce-9.c 
b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dce-9.c
new file mode 100644
index 00000000000..e1ffa7f038d
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dce-9.c
@@ -0,0 +1,10 @@
+/* { dg-do compile } */
+/* { dg-options "-O2 -fdump-tree-cddce1" } */
+
+int main()
+{
+  while(1)
+    for(int i=0; i<9000000; i++){}
+}
+
+/* { dg-final { scan-tree-dump-not "if" "cddce1" } } */
diff --git a/gcc/tree-ssa-dce.c b/gcc/tree-ssa-dce.c
index c4907af923c..372e0691ae6 100644
--- a/gcc/tree-ssa-dce.c
+++ b/gcc/tree-ssa-dce.c
@@ -436,7 +436,7 @@ find_obviously_necessary_stmts (bool aggressive)
 
       for (auto loop : loops_list (cfun, 0))
        /* For loops without an exit do not mark any condition.  */
-       if (loop->exits->next && !finite_loop_p (loop))
+       if (loop->exits->next->e && !finite_loop_p (loop))
          {
            if (dump_file)
              fprintf (dump_file, "cannot prove finiteness of loop %i\n",
-- 
2.31.1

Reply via email to