https://gcc.gnu.org/g:273df6bf14a66f2c587db97651715e033ec1ebb1

commit 273df6bf14a66f2c587db97651715e033ec1ebb1
Author: Mikael Morin <mik...@gcc.gnu.org>
Date:   Sun Jun 29 12:58:32 2025 +0200

    Suppression gfc_conv_descriptor_version compil' OK

Diff:
---
 gcc/fortran/trans-array.cc      | 24 +++++++++++++-----------
 gcc/fortran/trans-descriptor.cc | 18 ++++++++++++++++--
 gcc/fortran/trans-descriptor.h  |  3 ++-
 gcc/fortran/trans.cc            |  5 ++---
 4 files changed, 33 insertions(+), 17 deletions(-)

diff --git a/gcc/fortran/trans-array.cc b/gcc/fortran/trans-array.cc
index 861872303d18..a301b0d06aa6 100644
--- a/gcc/fortran/trans-array.cc
+++ b/gcc/fortran/trans-array.cc
@@ -6205,10 +6205,11 @@ gfc_array_allocate (gfc_se * se, gfc_expr * expr, tree 
status, tree errmsg,
                     build_tree_list (NULL_TREE, alloc),
                     DECL_ATTRIBUTES (omp_alt_alloc));
       omp_alt_alloc = build_call_expr (omp_alt_alloc, 3, align, sz, alloc);
-      succ_add_expr = fold_build2_loc (input_location, MODIFY_EXPR,
-                                      void_type_node,
-                                      gfc_conv_descriptor_version (se->expr),
+      stmtblock_t tmp_block;
+      gfc_init_block (&tmp_block);
+      gfc_conv_descriptor_version_set (&tmp_block, se->expr,
                                       build_int_cst (integer_type_node, 1));
+      succ_add_expr = gfc_finish_block (&tmp_block);
     }
 
   /* The allocatable variant takes the old pointer as first argument.  */
@@ -10340,10 +10341,12 @@ structure_alloc_comps (gfc_symbol * der_type, tree 
decl, tree dest,
                {
                  tree cd, t;
                  if (c->attr.pdt_array)
-                   cd = fold_build2_loc (input_location, EQ_EXPR,
-                                         boolean_type_node,
-                                         gfc_conv_descriptor_version (comp),
-                                         build_int_cst (integer_type_node, 1));
+                   {
+                     tree version = gfc_conv_descriptor_version_get (comp);
+                     cd = fold_build2_loc (input_location, EQ_EXPR,
+                                           boolean_type_node, version,
+                                           build_int_cst (integer_type_node, 
1));
+                   }
                  else
                    cd = gfc_omp_call_is_alloc (tmp);
                  t = builtin_decl_explicit (BUILT_IN_GOMP_FREE);
@@ -10353,8 +10356,8 @@ structure_alloc_comps (gfc_symbol * der_type, tree 
decl, tree dest,
                  gfc_init_block (&tblock);
                  gfc_add_expr_to_block (&tblock, t);
                  if (c->attr.pdt_array)
-                   gfc_add_modify (&tblock, gfc_conv_descriptor_version (comp),
-                                   integer_zero_node);
+                   gfc_conv_descriptor_version_set (&tblock, comp,
+                                                    integer_zero_node);
                  tmp = build3_loc (input_location, COND_EXPR, void_type_node,
                                    cd, gfc_finish_block (&tblock),
                                    gfc_call_free (tmp));
@@ -11361,7 +11364,7 @@ gfc_alloc_allocatable_for_assignment (gfc_loopinfo 
*loop,
        {
          tree cond, omp_tmp;
          cond = fold_build2_loc (input_location, EQ_EXPR, boolean_type_node,
-                                 gfc_conv_descriptor_version (desc),
+                                 gfc_conv_descriptor_version_get (desc),
                                  build_int_cst (integer_type_node, 1));
          omp_tmp = builtin_decl_explicit (BUILT_IN_GOMP_REALLOC);
          omp_tmp = build_call_expr_loc (input_location, omp_tmp, 4,
@@ -11472,7 +11475,6 @@ void
 gfc_trans_class_array (gfc_symbol * sym, gfc_wrapped_block * block)
 {
   tree type, etype;
-  tree tmp;
   tree descriptor;
   stmtblock_t init;
   int rank;
diff --git a/gcc/fortran/trans-descriptor.cc b/gcc/fortran/trans-descriptor.cc
index 0956343aad92..f488e87663e9 100644
--- a/gcc/fortran/trans-descriptor.cc
+++ b/gcc/fortran/trans-descriptor.cc
@@ -298,8 +298,8 @@ gfc_conv_descriptor_rank (tree desc)
 }
 
 
-tree
-gfc_conv_descriptor_version (tree desc)
+static tree
+get_descriptor_version (tree desc)
 {
   tree tmp;
   tree dtype;
@@ -312,6 +312,20 @@ gfc_conv_descriptor_version (tree desc)
                          dtype, tmp, NULL_TREE);
 }
 
+tree
+gfc_conv_descriptor_version_get (tree desc)
+{
+  return non_lvalue_loc (input_location, get_descriptor_version (desc));
+}
+
+void
+gfc_conv_descriptor_version_set (stmtblock_t *block, tree desc,
+                                tree value)
+{
+  tree t = get_descriptor_version (desc);
+  gfc_add_modify (block, t, fold_convert (TREE_TYPE (t), value));
+}
+
 
 /* Return the element length from the descriptor dtype field.  */
 
diff --git a/gcc/fortran/trans-descriptor.h b/gcc/fortran/trans-descriptor.h
index 6149dc295ed5..3f4fd92df117 100644
--- a/gcc/fortran/trans-descriptor.h
+++ b/gcc/fortran/trans-descriptor.h
@@ -30,7 +30,6 @@ tree gfc_get_cfi_dim_sm (tree desc, tree idx);
 
 
 tree gfc_conv_descriptor_rank (tree desc);
-tree gfc_conv_descriptor_version (tree desc);
 tree gfc_conv_descriptor_attribute (tree desc);
 tree gfc_conv_descriptor_type (tree desc);
 tree gfc_get_descriptor_dimension (tree desc);
@@ -41,6 +40,7 @@ tree gfc_conv_descriptor_data_get (tree desc);
 tree gfc_conv_descriptor_offset_get (tree desc);
 tree gfc_conv_descriptor_dtype_get (tree desc);
 tree gfc_conv_descriptor_elem_len_get (tree desc);
+tree gfc_conv_descriptor_version_get (tree desc);
 tree gfc_conv_descriptor_span_get (tree desc);
 
 tree gfc_conv_descriptor_stride_get (tree desc, tree dim);
@@ -52,6 +52,7 @@ void gfc_conv_descriptor_data_set (stmtblock_t *block, tree 
desc, tree value);
 void gfc_conv_descriptor_offset_set (stmtblock_t *block, tree desc, tree 
value);
 void gfc_conv_descriptor_dtype_set (stmtblock_t *block, tree desc, tree value);
 void gfc_conv_descriptor_elem_len_set (stmtblock_t *block, tree desc, tree 
value);
+void gfc_conv_descriptor_version_set (stmtblock_t *block, tree desc, tree 
value);
 void gfc_conv_descriptor_span_set (stmtblock_t *block, tree desc, tree value);
 void gfc_conv_descriptor_stride_set (stmtblock_t *block, tree desc, tree dim, 
tree value);
 void gfc_conv_descriptor_lbound_set (stmtblock_t *block, tree desc, tree dim, 
tree value);
diff --git a/gcc/fortran/trans.cc b/gcc/fortran/trans.cc
index 2a5ec3bba67e..9d525e0c51ee 100644
--- a/gcc/fortran/trans.cc
+++ b/gcc/fortran/trans.cc
@@ -1915,7 +1915,7 @@ gfc_deallocate_with_status (tree pointer, tree status, 
tree errmsg, tree errlen,
          tree cond, omp_tmp;
          if (descr)
            cond = fold_build2_loc (input_location, EQ_EXPR, boolean_type_node,
-                                   gfc_conv_descriptor_version (descr),
+                                   gfc_conv_descriptor_version_get (descr),
                                    integer_one_node);
          else
            cond = gfc_omp_call_is_alloc (pointer);
@@ -1929,8 +1929,7 @@ gfc_deallocate_with_status (tree pointer, tree status, 
tree errmsg, tree errlen,
       gfc_add_modify (&non_null, pointer, build_int_cst (TREE_TYPE (pointer),
                                                         0));
       if (flag_openmp_allocators && descr)
-       gfc_add_modify (&non_null, gfc_conv_descriptor_version (descr),
-                       integer_zero_node);
+       gfc_conv_descriptor_version_set (&non_null, descr, integer_zero_node);
 
       if (status != NULL_TREE && !integer_zerop (status))
        {

Reply via email to