Commit c96111c0 by Roger Sayle Committed by Roger Sayle

trans-array.c (gfc_conv_loop_setup): Test whether the loop stride is one...


	* trans-array.c (gfc_conv_loop_setup):  Test whether the loop
	stride is one, to avoid fold_build2 introducing a useless
	NON_LVALUE_EXPR node.

From-SVN: r120500
parent afe1a916
2007-01-05 Roger Sayle <roger@eyesopen.com>
* trans-array.c (gfc_conv_loop_setup): Test whether the loop
stride is one, to avoid fold_build2 introducing a useless
NON_LVALUE_EXPR node.
2007-01-05 Tobias Burnus <burnus@net-b.de>
* symbol.c (check_conflict): Fix error message.
......
......@@ -3141,8 +3141,10 @@ gfc_conv_loop_setup (gfc_loopinfo * loop)
{
/* Calculate the offset relative to the loop variable.
First multiply by the stride. */
tmp = fold_build2 (MULT_EXPR, gfc_array_index_type,
loop->from[n], info->stride[n]);
tmp = loop->from[n];
if (!integer_onep (info->stride[n]))
tmp = fold_build2 (MULT_EXPR, gfc_array_index_type,
tmp, info->stride[n]);
/* Then subtract this from our starting value. */
tmp = fold_build2 (MINUS_EXPR, gfc_array_index_type,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment