Ubsan builtins use the plus,minus and multiply operations under the
covers, but they are not relation aware. This patch queries for a
relation between the 2 operands and passes that on to range-ops.
This resolves gcc.dg/pr97505.c when operating in ranger-only mode, and
with that, ranger-only mode runs the gcc testsuite clean on
x86_64-pc-linux-gnu.
If there are no objections, I'd like to change the default mode to
ranger only, and see if something shows up on any other architectures,
or in any other places. We can easily switch back if need be.
I'll keep running things in hybrid mode locally to ensure we don't start
losing parity with legacy EVRP. Does this seem reasonable?
Andrew
commit 9693ecdf7ed5dde9618d06560697ff8ee5e1e6b7
Author: Andrew MacLeod <amacl...@redhat.com>
Date: Mon Jul 12 14:38:42 2021 -0400
Add relation processing to ubsan builtins.
Ubsan builtins call the plus/minus/multiple fold routines, but did not
use any relation information between the 2 operands that is available.
query and pass any relations.
This resolves gcc.dg/pr97505.c when operating in ranger-only mode.
* gimple-range-fold.cc (fold_using_range::range_of_builtin_ubsan_call):
Query relation between the 2 operands and use it.
diff --git a/gcc/gimple-range-fold.cc b/gcc/gimple-range-fold.cc
index 1fa4ace32b9..eff5d1f89f2 100644
--- a/gcc/gimple-range-fold.cc
+++ b/gcc/gimple-range-fold.cc
@@ -825,12 +825,14 @@ fold_using_range::range_of_builtin_ubsan_call (irange &r, gcall *call,
tree arg1 = gimple_call_arg (call, 1);
src.get_operand (ir0, arg0);
src.get_operand (ir1, arg1);
+ // Check for any relation between arg0 and arg1.
+ relation_kind relation = src.query_relation (arg0, arg1);
bool saved_flag_wrapv = flag_wrapv;
// Pretend the arithmetic is wrapping. If there is any overflow,
// we'll complain, but will actually do wrapping operation.
flag_wrapv = 1;
- op->fold_range (r, type, ir0, ir1);
+ op->fold_range (r, type, ir0, ir1, relation);
flag_wrapv = saved_flag_wrapv;
// If for both arguments vrp_valueize returned non-NULL, this should