aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-vrp.cc
diff options
context:
space:
mode:
authorMartin Liska <mliska@suse.cz>2022-11-08 12:36:43 +0100
committerMartin Liska <mliska@suse.cz>2022-11-08 12:36:43 +0100
commit4b13c73bba935443be3207abf26f7ba05f79badc (patch)
treea6bb1525d07859fa8fc6f61dd13df7ddfd1ac254 /gcc/tree-vrp.cc
parent33f5dde0cd15df9cf89b29280d4ff5fcf7b30e66 (diff)
parentfa271afb58423014e2feef9f15c1a87428e64ddc (diff)
Merge branch 'master' into devel/sphinxdevel/sphinx
Diffstat (limited to 'gcc/tree-vrp.cc')
-rw-r--r--gcc/tree-vrp.cc9
1 files changed, 9 insertions, 0 deletions
diff --git a/gcc/tree-vrp.cc b/gcc/tree-vrp.cc
index 39f7eb7a75e..3393c73a7db 100644
--- a/gcc/tree-vrp.cc
+++ b/gcc/tree-vrp.cc
@@ -4501,6 +4501,15 @@ public:
bool fold_stmt (gimple_stmt_iterator *gsi) override
{
+ gimple *s = gsi_stmt (*gsi);
+ // If this is a block ending condition, and there are inferred ranges,
+ // reparse the block to see if there are any transitive inferred ranges.
+ if (is_a<gcond *> (s))
+ {
+ basic_block bb = gimple_bb (s);
+ if (bb && s == gimple_outgoing_range_stmt_p (bb))
+ m_ranger->register_transitive_inferred_ranges (bb);
+ }
bool ret = m_simplifier.simplify (gsi);
if (!ret)
ret = m_ranger->fold_stmt (gsi, follow_single_use_edges);