Hi,
When dealing with PR62173, we found places in which overflow check on SCEVs
can be improved by range information. This patch addresses one of them.
Richard once suggested that we should trace range info all the way through
SCEV thus have it on CHREC structure. But as far as IVOPTs is concerned,
there is already the information because for each IV, we have the
corresponding ssa name field. The only problem is GCC now releases this
field to make iv dump routines easier. This is a trivial patch fixing this.
Bootstrap and test along with the other one. Is it OK?
Thanks,
bin
2015-02-13 Bin Cheng <bin.ch...@arm.com>
PR tree-optimization/62173
* tree-ssa-loop-ivopts.c (dump_iv): New parameter.
(dump_use, dump_cand, find_induction_variables): Pass new argument
to dump_iv.
(record_use): Preserve the ssa name information in IV.
Index: gcc/tree-ssa-loop-ivopts.c
===================================================================
--- gcc/tree-ssa-loop-ivopts.c (revision 219574)
+++ gcc/tree-ssa-loop-ivopts.c (working copy)
@@ -498,9 +498,9 @@ single_dom_exit (struct loop *loop)
/* Dumps information about the induction variable IV to FILE. */
void
-dump_iv (FILE *file, struct iv *iv)
+dump_iv (FILE *file, struct iv *iv, bool dump_name)
{
- if (iv->ssa_name)
+ if (iv->ssa_name && dump_name)
{
fprintf (file, "ssa name ");
print_generic_expr (file, iv->ssa_name, TDF_SLIM);
@@ -573,7 +573,7 @@ dump_use (FILE *file, struct iv_use *use)
print_generic_expr (file, *use->op_p, TDF_SLIM);
fprintf (file, "\n");
- dump_iv (file, use->iv);
+ dump_iv (file, use->iv, false);
if (use->related_cands)
{
@@ -657,7 +657,7 @@ dump_cand (FILE *file, struct iv_cand *cand)
break;
}
- dump_iv (file, iv);
+ dump_iv (file, iv, false);
}
/* Returns the info for ssa version VER. */
@@ -1269,7 +1269,7 @@ find_induction_variables (struct ivopts_data *data
EXECUTE_IF_SET_IN_BITMAP (data->relevant, 0, i, bi)
{
if (ver_info (data, i)->iv)
- dump_iv (dump_file, ver_info (data, i)->iv);
+ dump_iv (dump_file, ver_info (data, i)->iv, true);
}
}
@@ -1291,10 +1291,6 @@ record_use (struct ivopts_data *data, tree *use_p,
use->op_p = use_p;
use->related_cands = BITMAP_ALLOC (NULL);
- /* To avoid showing ssa name in the dumps, if it was not reset by the
- caller. */
- iv->ssa_name = NULL_TREE;
-
if (dump_file && (dump_flags & TDF_DETAILS))
dump_use (dump_file, use);