diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 305646fef5fdaa008c0621775da5420246b96a81..86de8bdac6eb9c7538488fd9daa4ed285211c03f 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,8 @@ +2012-01-04 Mikael Morin <mikael@gcc.gnu.org> + + * trans-expr.c (gfc_conv_expr): Move address taking... + (gfc_conv_expr_reference): ... here. + 2012-01-04 Thomas Koenig <tkoenig@gcc.gnu.org> PR fortran/49693 diff --git a/gcc/fortran/trans-expr.c b/gcc/fortran/trans-expr.c index 2ffa9fc2af7c36bf09cfaa378e08c9735f0558e5..12d382de2f6b7bce54c43eb51a45246c858d37d6 100644 --- a/gcc/fortran/trans-expr.c +++ b/gcc/fortran/trans-expr.c @@ -5331,8 +5331,6 @@ gfc_conv_expr (gfc_se * se, gfc_expr * expr) /* Substitute a scalar expression evaluated outside the scalarization loop. */ se->expr = ss_info->data.scalar.value; - if (ss_info->type == GFC_SS_REFERENCE) - se->expr = gfc_build_addr_expr (NULL_TREE, se->expr); se->string_length = ss_info->string_length; gfc_advance_se_ss_chain (se); return; @@ -5465,6 +5463,7 @@ gfc_conv_expr_reference (gfc_se * se, gfc_expr * expr) /* Returns a reference to the scalar evaluated outside the loop for this case. */ gfc_conv_expr (se, expr); + se->expr = gfc_build_addr_expr (NULL_TREE, se->expr); return; }