diff options
author | Bin Cheng <bin.cheng@arm.com> | 2017-05-02 16:18:42 +0000 |
---|---|---|
committer | Bin Cheng <amker@gcc.gnu.org> | 2017-05-02 16:18:42 +0000 |
commit | d6176f728590716d95bab9ba3622446919dbf079 (patch) | |
tree | 8e908e928bb96de5ffaaf3897578a12409f9f602 /gcc/tree-ssa-loop-ivopts.c | |
parent | 1136cae41bea892b33586aa52e90889b736fce53 (diff) | |
download | gcc-d6176f728590716d95bab9ba3622446919dbf079.zip gcc-d6176f728590716d95bab9ba3622446919dbf079.tar.gz gcc-d6176f728590716d95bab9ba3622446919dbf079.tar.bz2 |
* tree-ssa-loop-ivopts.c (rewrite_use_address): Simple refactor.
From-SVN: r247516
Diffstat (limited to 'gcc/tree-ssa-loop-ivopts.c')
-rw-r--r-- | gcc/tree-ssa-loop-ivopts.c | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/gcc/tree-ssa-loop-ivopts.c b/gcc/tree-ssa-loop-ivopts.c index 409a35d..840bde4 100644 --- a/gcc/tree-ssa-loop-ivopts.c +++ b/gcc/tree-ssa-loop-ivopts.c @@ -7361,9 +7361,6 @@ rewrite_use_address (struct ivopts_data *data, struct iv_use *use, struct iv_cand *cand) { aff_tree aff; - gimple_stmt_iterator bsi = gsi_for_stmt (use->stmt); - tree base_hint = NULL_TREE; - tree ref, iv; bool ok; adjust_iv_update_pos (cand, use); @@ -7382,17 +7379,18 @@ rewrite_use_address (struct ivopts_data *data, based on an object, the base of the reference is in some subexpression of the use -- but these will use pointer types, so they are recognized by the create_mem_ref heuristics anyway. */ - if (cand->iv->base_object) - base_hint = var_at_stmt (data->current_loop, cand, use->stmt); - - iv = var_at_stmt (data->current_loop, cand, use->stmt); + tree iv = var_at_stmt (data->current_loop, cand, use->stmt); + tree base_hint = (cand->iv->base_object) ? iv : NULL_TREE; + gimple_stmt_iterator bsi = gsi_for_stmt (use->stmt); tree type = TREE_TYPE (*use->op_p); unsigned int align = get_object_alignment (*use->op_p); if (align != TYPE_ALIGN (type)) type = build_aligned_type (type, align); - ref = create_mem_ref (&bsi, type, &aff, - reference_alias_ptr_type (*use->op_p), - iv, base_hint, data->speed); + + tree ref = create_mem_ref (&bsi, type, &aff, + reference_alias_ptr_type (*use->op_p), + iv, base_hint, data->speed); + copy_ref_info (ref, *use->op_p); *use->op_p = ref; } |