2
0
mirror of git://gcc.gnu.org/git/gcc.git synced 2025-03-21 23:51:18 +08:00

tree-optimization/107865 - ICE with outlining of loops

The following makes sure to clear loops number of iterations when
outlining them as part of a SESE region as can happen with
auto-parallelization.  The referenced SSA names become stale otherwise.

	PR tree-optimization/107865
	* tree-cfg.cc (move_sese_region_to_fn): Free the number of
	iterations of moved loops.

	* gfortran.dg/graphite/pr107865.f90: New testcase.
This commit is contained in:
Richard Biener 2022-11-25 08:27:42 +01:00
parent f120196382
commit bcc2449384
2 changed files with 20 additions and 0 deletions
gcc
testsuite/gfortran.dg/graphite
tree-cfg.cc

@ -0,0 +1,18 @@
! { dg-do compile }
! { dg-options "-O1 -floop-parallelize-all -ftree-parallelize-loops=2" }
SUBROUTINE FNC (F)
IMPLICIT REAL (A-H)
DIMENSION F(N)
DO I = 1, 6
DO J = 1, 6
IF (J .NE. I) THEN
F(I) = F(I) + 1
END IF
END DO
END DO
RETURN
END

@ -7859,6 +7859,8 @@ move_sese_region_to_fn (struct function *dest_cfun, basic_block entry_bb,
if (bb->loop_father->header == bb)
{
class loop *this_loop = bb->loop_father;
/* Avoid the need to remap SSA names used in nb_iterations. */
free_numbers_of_iterations_estimates (this_loop);
class loop *outer = loop_outer (this_loop);
if (outer == loop
/* If the SESE region contains some bbs ending with