diff options
author | Richard Biener <rguenther@suse.de> | 2015-01-27 12:11:37 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2015-01-27 12:11:37 +0000 |
commit | 755359b75ee55bb1a34c34bb90ff91a11ad83568 (patch) | |
tree | 8c053b5da7f1c56db168b7cdd1a95df2d2d751cc /gcc/tree-vrp.c | |
parent | eb42aba984cee3983ebbd6df099ecceef8a837f2 (diff) | |
download | gcc-755359b75ee55bb1a34c34bb90ff91a11ad83568.zip gcc-755359b75ee55bb1a34c34bb90ff91a11ad83568.tar.gz gcc-755359b75ee55bb1a34c34bb90ff91a11ad83568.tar.bz2 |
tree-vrp.c (update_value_range): Intersect the range with old recorded SSA name range information.
2015-01-27 Richard Biener <rguenther@suse.de>
* tree-vrp.c (update_value_range): Intersect the range with
old recorded SSA name range information.
From-SVN: r220164
Diffstat (limited to 'gcc/tree-vrp.c')
-rw-r--r-- | gcc/tree-vrp.c | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/gcc/tree-vrp.c b/gcc/tree-vrp.c index c5ca287..2bc22c6 100644 --- a/gcc/tree-vrp.c +++ b/gcc/tree-vrp.c @@ -847,6 +847,23 @@ update_value_range (const_tree var, value_range_t *new_vr) value_range_t *old_vr; bool is_new; + /* If there is a value-range on the SSA name from earlier analysis + factor that in. */ + if (INTEGRAL_TYPE_P (TREE_TYPE (var))) + { + wide_int min, max; + value_range_type rtype = get_range_info (var, &min, &max); + if (rtype == VR_RANGE || rtype == VR_ANTI_RANGE) + { + value_range_d nr; + nr.type = rtype; + nr.min = wide_int_to_tree (TREE_TYPE (var), min); + nr.max = wide_int_to_tree (TREE_TYPE (var), max); + nr.equiv = NULL; + vrp_intersect_ranges (new_vr, &nr); + } + } + /* Update the value range, if necessary. */ old_vr = get_value_range (var); is_new = old_vr->type != new_vr->type |