diff options
author | Richard Guenther <rguenther@suse.de> | 2010-11-04 15:19:19 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2010-11-04 15:19:19 +0000 |
commit | f2b01cfb6dcbf8dd471eee611d26c0cf094683f5 (patch) | |
tree | f3eb52d8af926dd9719f0f6e47ce85a8efb2f2f9 /gcc/gcse.c | |
parent | 9f2fbc99445e45c894c6170bef9d7e10ba8cc2d9 (diff) | |
download | gcc-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.c | 18 |
1 files changed, 15 insertions, 3 deletions
@@ -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; } |