diff options
author | Aldy Hernandez <aldyh@redhat.com> | 2019-10-03 08:08:50 +0000 |
---|---|---|
committer | Aldy Hernandez <aldyh@gcc.gnu.org> | 2019-10-03 08:08:50 +0000 |
commit | 38a734350fd787da1b4bcf9b4e0a99ed2adb5eae (patch) | |
tree | 4f5d0ec3eca5f40efce5cb8725875e0f0d1cf2d0 /gcc/vr-values.c | |
parent | 0a8c8f4d6578fac21adc0e156861c4b47bed4418 (diff) | |
download | gcc-38a734350fd787da1b4bcf9b4e0a99ed2adb5eae.zip gcc-38a734350fd787da1b4bcf9b4e0a99ed2adb5eae.tar.gz gcc-38a734350fd787da1b4bcf9b4e0a99ed2adb5eae.tar.bz2 |
Makefile.in (OBJS): Add range.o and range-op.o.
* Makefile.in (OBJS): Add range.o and range-op.o.
Remove wide-int-range.o.
* function-tests.c (test_ranges): New.
(function_tests_c_tests): Call test_ranges.
* ipa-cp.c (ipa_vr_operation_and_type_effects): Call
range_fold_unary_expr instead of extract_range_from_unary_expr.
* ipa-prop.c (ipa_compute_jump_functions_for_edge): Same.
* range-op.cc: New file.
* range-op.h: New file.
* range.cc: New file.
* range.h: New file.
* selftest.h (range_tests): New prototype.
* ssa.h: Include range.h.
* tree-vrp.c (value_range_base::value_range_base): New
constructors.
(value_range_base::singleton_p): Do not call
ranges_from_anti_range until sure we will need to.
(value_range_base::type): Rename gcc_assert to
gcc_checking_assert.
(vrp_val_is_max): New argument.
(vrp_val_is_min): Same.
(wide_int_range_set_zero_nonzero_bits): Move from
wide-int-range.cc.
(extract_range_into_wide_ints): Remove.
(extract_range_from_multiplicative_op): Remove.
(extract_range_from_pointer_plus_expr): Abstract POINTER_PLUS code
from extract_range_from_binary_expr.
(extract_range_from_plus_minus_expr): Abstract PLUS/MINUS code
from extract_range_from_binary_expr.
(extract_range_from_binary_expr): Remove.
(normalize_for_range_ops): New.
(range_fold_binary_expr): New.
(range_fold_unary_expr): New.
(value_range_base::num_pairs): New.
(value_range_base::lower_bound): New.
(value_range_base::upper_bound): New.
(value_range_base::upper_bound): New.
(value_range_base::contains_p): New.
(value_range_base::invert): New.
(value_range_base::union_): New.
(value_range_base::intersect): New.
(range_compatible_p): New.
(value_range_base::operator==): New.
(determine_value_range_1): Call range_fold_*expr instead of
extract_range_from_*expr.
* tree-vrp.h (class value_range_base): Add new constructors.
Add methods for union_, intersect, operator==, contains_p,
num_pairs, lower_bound, upper_bound, invert.
(vrp_val_is_min): Add handle_pointers argument.
(vrp_val_is_max): Same.
(extract_range_from_unary_expr): Remove.
(extract_range_from_binary_expr): Remove.
(range_fold_unary_expr): New.
(range_fold_binary_expr): New.
* vr-values.c (vr_values::extract_range_from_binary_expr): Call
range_fold_binary_expr instead of extract_range_from_binary_expr.
(vr_values::extract_range_basic): Same.
(vr_values::extract_range_from_unary_expr): Call
range_fold_unary_expr instead of extract_range_from_unary_expr.
* wide-int-range.cc: Remove.
* wide-int-range.h: Remove.
From-SVN: r276504
Diffstat (limited to 'gcc/vr-values.c')
-rw-r--r-- | gcc/vr-values.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/gcc/vr-values.c b/gcc/vr-values.c index 0ebb6e3..3acbfc6 100644 --- a/gcc/vr-values.c +++ b/gcc/vr-values.c @@ -46,8 +46,10 @@ along with GCC; see the file COPYING3. If not see #include "case-cfn-macros.h" #include "alloc-pool.h" #include "attribs.h" +#include "range.h" #include "vr-values.h" #include "cfghooks.h" +#include "range-op.h" /* Set value range VR to a non-negative range of type TYPE. */ @@ -803,7 +805,7 @@ vr_values::extract_range_from_binary_expr (value_range *vr, vrp_val_max (expr_type)); } - ::extract_range_from_binary_expr (vr, code, expr_type, &vr0, &vr1); + range_fold_binary_expr (vr, code, expr_type, &vr0, &vr1); /* Set value_range for n in following sequence: def = __builtin_memchr (arg, 0, sz) @@ -864,7 +866,7 @@ vr_values::extract_range_from_binary_expr (value_range *vr, else n_vr1.set (VR_RANGE, op1, op1); - ::extract_range_from_binary_expr (vr, code, expr_type, &vr0, &n_vr1); + range_fold_binary_expr (vr, code, expr_type, &vr0, &n_vr1); } if (vr->varying_p () @@ -888,7 +890,7 @@ vr_values::extract_range_from_binary_expr (value_range *vr, else n_vr0.set (op0); - ::extract_range_from_binary_expr (vr, code, expr_type, &n_vr0, &vr1); + range_fold_binary_expr (vr, code, expr_type, &n_vr0, &vr1); } /* If we didn't derive a range for MINUS_EXPR, and @@ -929,7 +931,7 @@ vr_values::extract_range_from_unary_expr (value_range *vr, enum tree_code code, else vr0.set_varying (type); - ::extract_range_from_unary_expr (vr, code, type, &vr0, TREE_TYPE (op0)); + range_fold_unary_expr (vr, code, type, &vr0, TREE_TYPE (op0)); } @@ -1427,8 +1429,7 @@ vr_values::extract_range_basic (value_range *vr, gimple *stmt) type, op0); extract_range_from_unary_expr (&vr1, NOP_EXPR, type, op1); - ::extract_range_from_binary_expr (vr, subcode, type, - &vr0, &vr1); + range_fold_binary_expr (vr, subcode, type, &vr0, &vr1); flag_wrapv = saved_flag_wrapv; } return; |