aboutsummaryrefslogtreecommitdiff
path: root/gcc/gcse.c
diff options
context:
space:
mode:
authorRichard Guenther <rguenther@suse.de>2010-11-04 15:19:19 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2010-11-04 15:19:19 +0000
commitf2b01cfb6dcbf8dd471eee611d26c0cf094683f5 (patch)
treef3eb52d8af926dd9719f0f6e47ce85a8efb2f2f9 /gcc/gcse.c
parent9f2fbc99445e45c894c6170bef9d7e10ba8cc2d9 (diff)
downloadgcc-f2b01cfb6dcbf8dd471eee611d26c0cf094683f5.zip
gcc-f2b01cfb6dcbf8dd471eee611d26c0cf094683f5.tar.gz
gcc-f2b01cfb6dcbf8dd471eee611d26c0cf094683f5.tar.bz2
re PR tree-optimization/46183 (ICE: in calc_dfs_tree, at dominance.c:396 with -O -fno-dse -fgcse -ftree-pre)
2010-11-04 Richard Guenther <rguenther@suse.de> PR rtl-optimization/46183 * gcse.c (execute_rtl_cprop): Cleanup the CFG if something changed. (execute_rtl_pre): Likewise. (execute_rtl_hoist): Likewise. * gcc.dg/torture/pr46183.c: New testcase. From-SVN: r166316
Diffstat (limited to 'gcc/gcse.c')
-rw-r--r--gcc/gcse.c18
1 files changed, 15 insertions, 3 deletions
diff --git a/gcc/gcse.c b/gcc/gcse.c
index 70f0fac..595fdb2 100644
--- a/gcc/gcse.c
+++ b/gcc/gcse.c
@@ -5246,10 +5246,14 @@ gate_rtl_cprop (void)
static unsigned int
execute_rtl_cprop (void)
{
+ int changed;
delete_unreachable_blocks ();
df_set_flags (DF_LR_RUN_DCE);
df_analyze ();
- flag_rerun_cse_after_global_opts |= one_cprop_pass ();
+ changed = one_cprop_pass ();
+ flag_rerun_cse_after_global_opts |= changed;
+ if (changed)
+ cleanup_cfg (0);
return 0;
}
@@ -5265,9 +5269,13 @@ gate_rtl_pre (void)
static unsigned int
execute_rtl_pre (void)
{
+ int changed;
delete_unreachable_blocks ();
df_analyze ();
- flag_rerun_cse_after_global_opts |= one_pre_gcse_pass ();
+ changed = one_pre_gcse_pass ();
+ flag_rerun_cse_after_global_opts |= changed;
+ if (changed)
+ cleanup_cfg (0);
return 0;
}
@@ -5286,9 +5294,13 @@ gate_rtl_hoist (void)
static unsigned int
execute_rtl_hoist (void)
{
+ int changed;
delete_unreachable_blocks ();
df_analyze ();
- flag_rerun_cse_after_global_opts |= one_code_hoisting_pass ();
+ changed = one_code_hoisting_pass ();
+ flag_rerun_cse_after_global_opts |= changed;
+ if (changed)
+ cleanup_cfg (0);
return 0;
}