[PATCH] Fix PR66101

Richard Biener rguenther@suse.de
Tue May 12 13:42:00 GMT 2015


This fixes PR66101.

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

Richard.

2015-05-12  Richard Biener  <rguenther@suse.de>

	PR tree-optimization/66101
	* tree-ssa-dce.c (remove_dead_stmt): Properly mark loops for
	fixup if we turn a loop exit edge to a fallthru edge.

	* gcc.dg/torture/pr66101.c: New testcase.

Index: gcc/tree-ssa-dce.c
===================================================================
*** gcc/tree-ssa-dce.c	(revision 223044)
--- gcc/tree-ssa-dce.c	(working copy)
*************** remove_dead_stmt (gimple_stmt_iterator *
*** 1149,1155 ****
  	if (e != e2)
  	  {
  	    cfg_altered = true;
!             remove_edge (e2);
  	  }
  	else
  	  ei_next (&ei);
--- 1149,1160 ----
  	if (e != e2)
  	  {
  	    cfg_altered = true;
! 	    /* If we made a BB unconditionally exit a loop then this
! 	       transform alters the set of BBs in the loop.  Schedule
! 	       a fixup.  */
! 	    if (loop_exit_edge_p (bb->loop_father, e))
! 	      loops_state_set (LOOPS_NEED_FIXUP);
! 	    remove_edge (e2);
  	  }
  	else
  	  ei_next (&ei);
Index: gcc/testsuite/gcc.dg/torture/pr66101.c
===================================================================
*** gcc/testsuite/gcc.dg/torture/pr66101.c	(revision 0)
--- gcc/testsuite/gcc.dg/torture/pr66101.c	(working copy)
***************
*** 0 ****
--- 1,35 ----
+ /* { dg-do compile } */
+ 
+ #include <setjmp.h>
+ 
+ jmp_buf env;
+ 
+ int a, c, d, e;
+ 
+ int
+ bar ()
+ {
+   int b = *(long *) 7 == 5 ? : 0;
+   if (a || a > b)
+     longjmp (env, 0);
+   return 1;
+ }
+ 
+ void
+ foo ()
+ {
+   long f;
+   setjmp (env);
+   for (; d; c++)
+     switch (c)
+ case 0:
+       {
+ 	f = bar () >> 1;
+ 	if (e)
+ 	  goto L;
+ 	if (bar () >> 1)
+ 	  goto L;
+       }
+ L:
+     ;
+ }



More information about the Gcc-patches mailing list