https://gcc.gnu.org/g:6c4ebec3168114c4ebddcb81994004326d70952b
commit 6c4ebec3168114c4ebddcb81994004326d70952b Author: Mikael Morin <mik...@gcc.gnu.org> Date: Sat May 17 18:38:46 2025 +0200 Correction régression class_dummy_7 Correction régression pr63331 Diff: --- gcc/fortran/trans-array.cc | 16 +++++++++++++++- gcc/fortran/trans-decl.cc | 2 +- 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/gcc/fortran/trans-array.cc b/gcc/fortran/trans-array.cc index 0e478e1d3121..569e72563653 100644 --- a/gcc/fortran/trans-array.cc +++ b/gcc/fortran/trans-array.cc @@ -6281,7 +6281,21 @@ gfc_trans_array_bounds (tree type, gfc_symbol * sym, tree * poffset, offset = gfc_index_zero_node; tree spacing = GFC_TYPE_ARRAY_SPACING (type, 0); if (spacing && VAR_P (spacing)) - gfc_add_modify (pblock, spacing, elem_len); + { + tree spacing0; + if (sym->ts.type == BT_CLASS + && DECL_LANG_SPECIFIC (sym->backend_decl) + && GFC_DECL_SAVED_DESCRIPTOR (sym->backend_decl)) + { + tree class_desc = GFC_DECL_SAVED_DESCRIPTOR (sym->backend_decl); + tree array_desc = gfc_class_data_get (class_desc); + spacing0 = gfc_conv_array_spacing (array_desc, 0); + } + else + spacing0 = elem_len; + + gfc_add_modify (pblock, spacing, spacing0); + } for (dim = 0; dim < as->rank; dim++) { /* Evaluate non-constant array bound expressions. diff --git a/gcc/fortran/trans-decl.cc b/gcc/fortran/trans-decl.cc index 92a0ccdb3588..a16487106046 100644 --- a/gcc/fortran/trans-decl.cc +++ b/gcc/fortran/trans-decl.cc @@ -1345,7 +1345,7 @@ gfc_build_dummy_array_decl (gfc_symbol * sym, tree dummy) are not repacked. */ if (!flag_repack_arrays || sym->attr.target) { - if (as->type == AS_ASSUMED_SIZE) + if (as->type == AS_ASSUMED_SIZE && !is_classarray) packed = PACKED_FULL; } else