diff options
author | Jakub Jelinek <jakub@redhat.com> | 2019-11-23 11:05:31 +0100 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2019-11-23 11:05:31 +0100 |
commit | ba585b91532b5cb382f1e2d21be50e728bca1da0 (patch) | |
tree | 6f7a47c199276ff4edb1b2d1d49f104db70e995a /gcc/cse.c | |
parent | 41149acaff5ccb046ebf8ac7ae6eadb147f6f6b8 (diff) | |
download | gcc-ba585b91532b5cb382f1e2d21be50e728bca1da0.zip gcc-ba585b91532b5cb382f1e2d21be50e728bca1da0.tar.gz gcc-ba585b91532b5cb382f1e2d21be50e728bca1da0.tar.bz2 |
re PR rtl-optimization/92610 (ICE in calc_dfs_tree, at dominance.c:458 since r270940)
PR rtl-optimization/92610
* cse.c (rest_of_handle_cse2): Call cleanup_cfg (0) also if
cse_cfg_altered is set, even when tem is 0.
(rest_of_handle_cse_after_global_opts): Likewise.
* g++.dg/opt/pr92610.C: New test.
From-SVN: r278640
Diffstat (limited to 'gcc/cse.c')
-rw-r--r-- | gcc/cse.c | 4 |
1 files changed, 2 insertions, 2 deletions
@@ -7701,7 +7701,7 @@ rest_of_handle_cse2 (void) cse_cfg_altered |= cleanup_cfg (CLEANUP_CFG_CHANGED); timevar_pop (TV_JUMP); } - else if (tem == 1) + else if (tem == 1 || cse_cfg_altered) cse_cfg_altered |= cleanup_cfg (0); cse_not_expected = 1; @@ -7775,7 +7775,7 @@ rest_of_handle_cse_after_global_opts (void) cse_cfg_altered |= cleanup_cfg (CLEANUP_CFG_CHANGED); timevar_pop (TV_JUMP); } - else if (tem == 1) + else if (tem == 1 || cse_cfg_altered) cse_cfg_altered |= cleanup_cfg (0); flag_cse_follow_jumps = save_cfj; |