https://gcc.gnu.org/g:c9be2ad052f90cdc55f7a28f55f8f574fc17dc49

commit c9be2ad052f90cdc55f7a28f55f8f574fc17dc49
Author: Mikael Morin <mik...@gcc.gnu.org>
Date:   Mon May 26 22:49:46 2025 +0200

    Correction régression assign_10

Diff:
---
 gcc/fortran/trans-array.cc      |  2 +-
 gcc/fortran/trans-descriptor.cc | 10 +++++++++-
 gcc/fortran/trans-descriptor.h  |  2 +-
 3 files changed, 11 insertions(+), 3 deletions(-)

diff --git a/gcc/fortran/trans-array.cc b/gcc/fortran/trans-array.cc
index 27d8dda70573..dc4c0399cb2f 100644
--- a/gcc/fortran/trans-array.cc
+++ b/gcc/fortran/trans-array.cc
@@ -7825,7 +7825,7 @@ gfc_conv_expr_descriptor (gfc_se *se, gfc_expr *expr)
 
       gfc_set_descriptor (&loop.pre, parm, desc, expr, loop.dimen, codim,
                          ss, info, loop.from, loop.to, !se->data_not_needed,
-                         subref_array_target);
+                         subref_array_target, !se->direct_byref);
 
       desc = parm;
     }
diff --git a/gcc/fortran/trans-descriptor.cc b/gcc/fortran/trans-descriptor.cc
index e41809f0037a..600c1bd43a5a 100644
--- a/gcc/fortran/trans-descriptor.cc
+++ b/gcc/fortran/trans-descriptor.cc
@@ -2955,6 +2955,9 @@ gfc_set_temporary_descriptor (stmtblock_t *block, tree 
desc, tree class_src,
          tree this_lbound = shift_bounds ? gfc_index_zero_node : lbound[n];
          set_descriptor_dimension (block, desc, n, this_lbound, ubound[n],
                                    spacing[n], &offset, nullptr);
+         if (TREE_CODE (spacing[n]) == INTEGER_CST
+             && GFC_TYPE_ARRAY_SPACING (TREE_TYPE (desc), n) == NULL_TREE)
+           GFC_TYPE_ARRAY_SPACING (TREE_TYPE (desc), n) = spacing[n];
        }
     }
 
@@ -3024,7 +3027,7 @@ gfc_set_descriptor (stmtblock_t *block, tree dest, tree 
src, gfc_expr *src_expr,
                    int rank, int corank, gfc_ss *ss, gfc_array_info *info,
                    tree lowers[GFC_MAX_DIMENSIONS],
                    tree uppers[GFC_MAX_DIMENSIONS], bool data_needed,
-                   bool subref)
+                   bool subref, bool update_spacing_in_type)
 {
   int ndim = info->ref ? info->ref->u.ar.dimen : rank;
 
@@ -3138,6 +3141,11 @@ gfc_set_descriptor (stmtblock_t *block, tree dest, tree 
src, gfc_expr *src_expr,
       offset = fold_build2_loc (input_location, MINUS_EXPR,
                               TREE_TYPE (offset), offset, tmp);
 
+      if (update_spacing_in_type
+         && TREE_CODE (spacing) == INTEGER_CST
+         && GFC_TYPE_ARRAY_SPACING (TREE_TYPE (dest), dim) == NULL_TREE)
+       GFC_TYPE_ARRAY_SPACING (TREE_TYPE (dest), dim) = spacing;
+
       /* Store the new spacing.  */
       gfc_conv_descriptor_spacing_set (block, dest, gfc_rank_cst[dim], 
spacing);
     }
diff --git a/gcc/fortran/trans-descriptor.h b/gcc/fortran/trans-descriptor.h
index e431aeb9a7a3..4c4c82d227ab 100644
--- a/gcc/fortran/trans-descriptor.h
+++ b/gcc/fortran/trans-descriptor.h
@@ -91,7 +91,7 @@ void gfc_set_temporary_descriptor (stmtblock_t *, tree, tree, 
tree, tree,
 
 void gfc_set_descriptor (stmtblock_t *, tree, tree, gfc_expr *, int, int,
                         gfc_ss *, gfc_array_info *, tree [GFC_MAX_DIMENSIONS],
-                        tree [GFC_MAX_DIMENSIONS], bool, bool);
+                        tree [GFC_MAX_DIMENSIONS], bool, bool, bool);
 
 tree gfc_descr_init_count (tree, int, int, gfc_expr **, gfc_expr **,
                           stmtblock_t *, stmtblock_t *, tree *, tree,

Reply via email to