aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMikael Morin <mikael@gcc.gnu.org>2022-04-22 22:52:38 +0200
committerMikael Morin <mikael@gcc.gnu.org>2022-04-22 22:52:38 +0200
commit761dda57482295f9c41fcf87e5defa2ac1959f03 (patch)
tree2d904f79f3d57a2c164e221428866139b600acd3
parente72fbb6915c1dd1a52ecef55e10329e353cc3072 (diff)
downloadgcc-761dda57482295f9c41fcf87e5defa2ac1959f03.zip
gcc-761dda57482295f9c41fcf87e5defa2ac1959f03.tar.gz
gcc-761dda57482295f9c41fcf87e5defa2ac1959f03.tar.bz2
fortran: Generate an array temporary reference [PR102043]
This avoids regressing on char_cast_1.f90 and char_cast_2.f90 later in the patch series when the code generation for array references is changed to use pointer arithmetic. The regressing testcases match part of an array reference in the generated tree dump and it’s not clear how the pattern should be rewritten to match the equivalent with pointer arithmetic. This change uses a method specific to array temporaries to generate array-references, so that these array references are flagged as safe for array indexing and will not be updated to use pointer arithmetic. PR fortran/102043 gcc/fortran/ChangeLog: * trans-array.cc (gfc_conv_expr_descriptor): Use gfc_conv_tmp_array_ref.
-rw-r--r--gcc/fortran/trans-array.cc2
1 files changed, 1 insertions, 1 deletions
diff --git a/gcc/fortran/trans-array.cc b/gcc/fortran/trans-array.cc
index b3f8871..11e47c0 100644
--- a/gcc/fortran/trans-array.cc
+++ b/gcc/fortran/trans-array.cc
@@ -7723,7 +7723,7 @@ gfc_conv_expr_descriptor (gfc_se *se, gfc_expr *expr)
lse.ss = loop.temp_ss;
rse.ss = ss;
- gfc_conv_scalarized_array_ref (&lse, NULL);
+ gfc_conv_tmp_array_ref (&lse);
if (expr->ts.type == BT_CHARACTER)
{
gfc_conv_expr (&rse, expr);