diff options
author | Andrew Pinski <andrew_pinski@playstation.sony.com> | 2008-03-11 09:36:51 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2008-03-11 09:36:51 +0000 |
commit | 1ffe34d9f7823398e9937858cfdfbbd33e2d9130 (patch) | |
tree | f1231d387b8e29a423766fa3401b01369f01515b /gcc | |
parent | 7f2ad78b6dbee7d3124ba5fb4f953a3c5e22abde (diff) | |
download | gcc-1ffe34d9f7823398e9937858cfdfbbd33e2d9130.zip gcc-1ffe34d9f7823398e9937858cfdfbbd33e2d9130.tar.gz gcc-1ffe34d9f7823398e9937858cfdfbbd33e2d9130.tar.bz2 |
re PR tree-optimization/31358 (IV-OPTs produces a weird MEM_REF)
2008-03-11 Andrew Pinski <andrew_pinski@playstation.sony.com>
Richard Guenther <rguenther@suse.de>
PR tree-optimization/31358
* tree-ssa-loop-manip.c (create_iv): Call force_gimple_operand for
the step with a NULL_TREE.
* tree-ssa-loop-ivopts.c (find_bivs): Convert the step
to sizetype if type is a pointer type.
(add_candidate_1): Don't convert the base and step to
the generic type if the orginal type is a pointer type.
(add_iv_value_candidates): Use sizetype for the step
if type is a pointer type.
(cand_value_at): Likewise.
* tree-ssa-address.c (add_to_parts): Use POINTER_PLUS_EXPR
for pointer types.
* tree-affine.c (tree_to_aff_combination <POINTER_PLUS_EXPR>):
Don't convert the tem affine to the type.
(add_elt_to_tree): Use sizetype for the step if a pointer.
Use POINTER_PLUS_EXPR for pointers.
(aff_combination_to_tree): Use sizetype for the step if a
pointer.
Co-Authored-By: Richard Guenther <rguenther@suse.de>
From-SVN: r133102
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 22 | ||||
-rw-r--r-- | gcc/tree-affine.c | 37 | ||||
-rw-r--r-- | gcc/tree-ssa-loop-ivopts.c | 24 | ||||
-rw-r--r-- | gcc/tree-ssa-loop-manip.c | 2 |
4 files changed, 70 insertions, 15 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 3bb4cb0..3dae5cd 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,25 @@ +2008-03-11 Andrew Pinski <andrew_pinski@playstation.sony.com> + Richard Guenther <rguenther@suse.de> + + PR tree-optimization/31358 + * tree-ssa-loop-manip.c (create_iv): Call force_gimple_operand for + the step with a NULL_TREE. + * tree-ssa-loop-ivopts.c (find_bivs): Convert the step + to sizetype if type is a pointer type. + (add_candidate_1): Don't convert the base and step to + the generic type if the orginal type is a pointer type. + (add_iv_value_candidates): Use sizetype for the step + if type is a pointer type. + (cand_value_at): Likewise. + * tree-ssa-address.c (add_to_parts): Use POINTER_PLUS_EXPR + for pointer types. + * tree-affine.c (tree_to_aff_combination <POINTER_PLUS_EXPR>): + Don't convert the tem affine to the type. + (add_elt_to_tree): Use sizetype for the step if a pointer. + Use POINTER_PLUS_EXPR for pointers. + (aff_combination_to_tree): Use sizetype for the step if a + pointer. + 2008-03-10 Vladimir Makarov <vmakarov@redhat.com> * config/i386/sse.md (ssse3_pmaddubswv8hi3, ssse3_pmaddubswv4hi3): diff --git a/gcc/tree-affine.c b/gcc/tree-affine.c index b6c47d6..3a4d897 100644 --- a/gcc/tree-affine.c +++ b/gcc/tree-affine.c @@ -279,7 +279,6 @@ tree_to_aff_combination (tree expr, tree type, aff_tree *comb) case POINTER_PLUS_EXPR: tree_to_aff_combination (TREE_OPERAND (expr, 0), type, comb); tree_to_aff_combination (TREE_OPERAND (expr, 1), sizetype, &tmp); - aff_combination_convert (&tmp, type); aff_combination_add (comb, &tmp); return; @@ -350,29 +349,40 @@ add_elt_to_tree (tree expr, tree type, tree elt, double_int scale, aff_tree *comb) { enum tree_code code; + tree type1 = type; + if (POINTER_TYPE_P (type)) + type1 = sizetype; scale = double_int_ext_for_comb (scale, comb); - elt = fold_convert (type, elt); + elt = fold_convert (type1, elt); if (double_int_one_p (scale)) { if (!expr) - return elt; + return fold_convert (type, elt); + if (POINTER_TYPE_P (type)) + return fold_build2 (POINTER_PLUS_EXPR, type, expr, elt); return fold_build2 (PLUS_EXPR, type, expr, elt); } if (double_int_minus_one_p (scale)) { if (!expr) - return fold_build1 (NEGATE_EXPR, type, elt); + return fold_convert (type, fold_build1 (NEGATE_EXPR, type1, elt)); + if (POINTER_TYPE_P (type)) + { + elt = fold_build1 (NEGATE_EXPR, type1, elt); + return fold_build2 (POINTER_PLUS_EXPR, type, expr, elt); + } return fold_build2 (MINUS_EXPR, type, expr, elt); } if (!expr) - return fold_build2 (MULT_EXPR, type, elt, - double_int_to_tree (type, scale)); + return fold_convert (type, + fold_build2 (MULT_EXPR, type1, elt, + double_int_to_tree (type1, scale))); if (double_int_negative_p (scale)) { @@ -382,8 +392,14 @@ add_elt_to_tree (tree expr, tree type, tree elt, double_int scale, else code = PLUS_EXPR; - elt = fold_build2 (MULT_EXPR, type, elt, - double_int_to_tree (type, scale)); + elt = fold_build2 (MULT_EXPR, type1, elt, + double_int_to_tree (type1, scale)); + if (POINTER_TYPE_P (type)) + { + if (code == MINUS_EXPR) + elt = fold_build1 (NEGATE_EXPR, type1, elt); + return fold_build2 (POINTER_PLUS_EXPR, type, expr, elt); + } return fold_build2 (code, type, expr, elt); } @@ -396,6 +412,9 @@ aff_combination_to_tree (aff_tree *comb) tree expr = comb->rest; unsigned i; double_int off, sgn; + tree type1 = type; + if (POINTER_TYPE_P (type)) + type1 = sizetype; gcc_assert (comb->n == MAX_AFF_ELTS || comb->rest == NULL_TREE); @@ -415,7 +434,7 @@ aff_combination_to_tree (aff_tree *comb) off = comb->offset; sgn = double_int_one; } - return add_elt_to_tree (expr, type, double_int_to_tree (type, off), sgn, + return add_elt_to_tree (expr, type, double_int_to_tree (type1, off), sgn, comb); } diff --git a/gcc/tree-ssa-loop-ivopts.c b/gcc/tree-ssa-loop-ivopts.c index 02fe707f..9b406ce 100644 --- a/gcc/tree-ssa-loop-ivopts.c +++ b/gcc/tree-ssa-loop-ivopts.c @@ -914,7 +914,12 @@ find_bivs (struct ivopts_data *data) type = TREE_TYPE (PHI_RESULT (phi)); base = fold_convert (type, base); if (step) - step = fold_convert (type, step); + { + if (POINTER_TYPE_P (type)) + step = fold_convert (sizetype, step); + else + step = fold_convert (type, step); + } set_iv (data, PHI_RESULT (phi), base, step); found = true; @@ -2040,7 +2045,9 @@ add_candidate_1 (struct ivopts_data *data, { orig_type = TREE_TYPE (base); type = generic_type_for (orig_type); - if (type != orig_type) + /* Don't convert the base to the generic type for pointers as the generic + type is an integer type with the same size as the pointer type. */ + if (type != orig_type && !POINTER_TYPE_P (orig_type)) { base = fold_convert (type, base); step = fold_convert (type, step); @@ -2237,13 +2244,17 @@ add_iv_value_candidates (struct ivopts_data *data, { unsigned HOST_WIDE_INT offset; tree base; + tree basetype; add_candidate (data, iv->base, iv->step, false, use); /* The same, but with initial value zero. Make such variable important, since it is generic enough so that possibly many uses may be based on it. */ - add_candidate (data, build_int_cst (TREE_TYPE (iv->base), 0), + basetype = TREE_TYPE (iv->base); + if (POINTER_TYPE_P (basetype)) + basetype = sizetype; + add_candidate (data, build_int_cst (basetype, 0), iv->step, true, use); /* Third, try removing the constant offset. */ @@ -3671,10 +3682,13 @@ cand_value_at (struct loop *loop, struct iv_cand *cand, tree at, tree niter, aff_tree step, delta, nit; struct iv *iv = cand->iv; tree type = TREE_TYPE (iv->base); + tree steptype = type; + if (POINTER_TYPE_P (type)) + steptype = sizetype; - tree_to_aff_combination (iv->step, type, &step); + tree_to_aff_combination (iv->step, steptype, &step); tree_to_aff_combination (niter, TREE_TYPE (niter), &nit); - aff_combination_convert (&nit, type); + aff_combination_convert (&nit, steptype); aff_combination_mult (&nit, &step, &delta); if (stmt_after_increment (loop, cand, at)) aff_combination_add (&delta, &step); diff --git a/gcc/tree-ssa-loop-manip.c b/gcc/tree-ssa-loop-manip.c index 91aac3e..835b006 100644 --- a/gcc/tree-ssa-loop-manip.c +++ b/gcc/tree-ssa-loop-manip.c @@ -104,7 +104,7 @@ create_iv (tree base, tree step, tree var, struct loop *loop, } /* Gimplify the step if necessary. We put the computations in front of the loop (i.e. the step should be loop invariant). */ - step = force_gimple_operand (step, &stmts, true, var); + step = force_gimple_operand (step, &stmts, true, NULL_TREE); if (stmts) bsi_insert_on_edge_immediate (pe, stmts); |