aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-vrp.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2015-04-27 13:26:12 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2015-04-27 13:26:12 +0200
commit9c3cb3607913d35e96243a26b1ad4aaee1ad8a68 (patch)
tree71ff1501327cc81f60701d41ac26e0c9f1cb2a32 /gcc/tree-vrp.c
parent97d87f7502351f80784f77dbeb4119def98c133d (diff)
downloadgcc-9c3cb3607913d35e96243a26b1ad4aaee1ad8a68.zip
gcc-9c3cb3607913d35e96243a26b1ad4aaee1ad8a68.tar.gz
gcc-9c3cb3607913d35e96243a26b1ad4aaee1ad8a68.tar.bz2
re PR tree-optimization/65875 (ICE: Segmentation fault)
PR tree-optimization/65875 * tree-vrp.c (update_value_range): If in is_new case setting old_vr to VR_VARYING, also set new_vr to it. Remove old_vr->type == VR_VARYING test. (vrp_visit_phi_node): Return SSA_PROP_VARYING instead of SSA_PROP_INTERESTING if update_value_range returned true, but new range is VR_VARYING. * gcc.c-torture/compile/pr65875.c: New test. From-SVN: r222458
Diffstat (limited to 'gcc/tree-vrp.c')
-rw-r--r--gcc/tree-vrp.c18
1 files changed, 13 insertions, 5 deletions
diff --git a/gcc/tree-vrp.c b/gcc/tree-vrp.c
index e7ab23c..0ade55c 100644
--- a/gcc/tree-vrp.c
+++ b/gcc/tree-vrp.c
@@ -886,13 +886,18 @@ update_value_range (const_tree var, value_range_t *new_vr)
if (is_new)
{
/* Do not allow transitions up the lattice. The following
- is slightly more awkward than just new_vr->type < old_vr->type
+ is slightly more awkward than just new_vr->type < old_vr->type
because VR_RANGE and VR_ANTI_RANGE need to be considered
the same. We may not have is_new when transitioning to
- UNDEFINED or from VARYING. */
- if (new_vr->type == VR_UNDEFINED
- || old_vr->type == VR_VARYING)
- set_value_range_to_varying (old_vr);
+ UNDEFINED. If old_vr->type is VARYING, we shouldn't be
+ called. */
+ if (new_vr->type == VR_UNDEFINED)
+ {
+ BITMAP_FREE (new_vr->equiv);
+ set_value_range_to_varying (old_vr);
+ set_value_range_to_varying (new_vr);
+ return true;
+ }
else
set_value_range (old_vr, new_vr->type, new_vr->min, new_vr->max,
new_vr->equiv);
@@ -8941,6 +8946,9 @@ update_range:
fprintf (dump_file, "\n");
}
+ if (vr_result.type == VR_VARYING)
+ return SSA_PROP_VARYING;
+
return SSA_PROP_INTERESTING;
}