Blame SOURCES/gcc8-fortran-equivalence.patch

2985e0
diff --git a/gcc/fortran/gfortran.h b/gcc/fortran/gfortran.h
2985e0
index c373419..880630a 100644
2985e0
--- a/gcc/fortran/gfortran.h
2985e0
+++ b/gcc/fortran/gfortran.h
2985e0
@@ -2867,6 +2867,7 @@ bool gfc_merge_new_implicit (gfc_typespec *);
2985e0
 void gfc_set_implicit_none (bool, bool, locus *);
2985e0
 void gfc_check_function_type (gfc_namespace *);
2985e0
 bool gfc_is_intrinsic_typename (const char *);
2985e0
+bool check_conflict (symbol_attribute *, const char *, locus *);
2985e0
 
2985e0
 gfc_typespec *gfc_get_default_type (const char *, gfc_namespace *);
2985e0
 bool gfc_set_default_type (gfc_symbol *, int, gfc_namespace *);
2985e0
diff --git a/gcc/fortran/symbol.c b/gcc/fortran/symbol.c
2985e0
index 67ad504..29b40fd 100644
2985e0
--- a/gcc/fortran/symbol.c
2985e0
+++ b/gcc/fortran/symbol.c
2985e0
@@ -363,7 +363,7 @@ gfc_check_function_type (gfc_namespace *ns)
2985e0
                                 goto conflict_std;\
2985e0
                               }
2985e0
 
2985e0
-static bool
2985e0
+bool
2985e0
 check_conflict (symbol_attribute *attr, const char *name, locus *where)
2985e0
 {
2985e0
   static const char *dummy = "DUMMY", *save = "SAVE", *pointer = "POINTER",
2985e0
@@ -496,7 +496,9 @@ check_conflict (symbol_attribute *attr, const char *name, locus *where)
2985e0
   conf (allocatable, elemental);
2985e0
 
2985e0
   conf (in_common, automatic);
2985e0
+#if 0
2985e0
   conf (in_equivalence, automatic);
2985e0
+#endif
2985e0
   conf (result, automatic);
2985e0
   conf (use_assoc, automatic);
2985e0
   conf (dummy, automatic);
2985e0
diff --git a/gcc/fortran/trans-common.c b/gcc/fortran/trans-common.c
2985e0
index 36370eb..4cfaf61 100644
2985e0
--- a/gcc/fortran/trans-common.c
2985e0
+++ b/gcc/fortran/trans-common.c
2985e0
@@ -948,6 +948,61 @@ add_condition (segment_info *f, gfc_equiv *eq1, gfc_equiv *eq2)
2985e0
     confirm_condition (f, eq1, n, eq2);
2985e0
 }
2985e0
 
2985e0
+static void
2985e0
+accumulate_equivalence_attributes (symbol_attribute *dummy_symbol, gfc_equiv *e)
2985e0
+{
2985e0
+  symbol_attribute attr = e->expr->symtree->n.sym->attr;
2985e0
+
2985e0
+  dummy_symbol->dummy |= attr.dummy;
2985e0
+  dummy_symbol->pointer |= attr.pointer;
2985e0
+  dummy_symbol->target |= attr.target;
2985e0
+  dummy_symbol->external |= attr.external;
2985e0
+  dummy_symbol->intrinsic |= attr.intrinsic;
2985e0
+  dummy_symbol->allocatable |= attr.allocatable;
2985e0
+  dummy_symbol->elemental |= attr.elemental;
2985e0
+  dummy_symbol->recursive |= attr.recursive;
2985e0
+  dummy_symbol->in_common |= attr.in_common;
2985e0
+  dummy_symbol->result |= attr.result;
2985e0
+  dummy_symbol->in_namelist |= attr.in_namelist;
2985e0
+  dummy_symbol->optional |= attr.optional;
2985e0
+  dummy_symbol->entry |= attr.entry;
2985e0
+  dummy_symbol->function |= attr.function;
2985e0
+  dummy_symbol->subroutine |= attr.subroutine;
2985e0
+  dummy_symbol->dimension |= attr.dimension;
2985e0
+  dummy_symbol->in_equivalence |= attr.in_equivalence;
2985e0
+  dummy_symbol->use_assoc |= attr.use_assoc;
2985e0
+  dummy_symbol->cray_pointer |= attr.cray_pointer;
2985e0
+  dummy_symbol->cray_pointee |= attr.cray_pointee;
2985e0
+  dummy_symbol->data |= attr.data;
2985e0
+  dummy_symbol->value |= attr.value;
2985e0
+  dummy_symbol->volatile_ |= attr.volatile_;
2985e0
+  dummy_symbol->is_protected |= attr.is_protected;
2985e0
+  dummy_symbol->is_bind_c |= attr.is_bind_c;
2985e0
+  dummy_symbol->procedure |= attr.procedure;
2985e0
+  dummy_symbol->proc_pointer |= attr.proc_pointer;
2985e0
+  dummy_symbol->abstract |= attr.abstract;
2985e0
+  dummy_symbol->asynchronous |= attr.asynchronous;
2985e0
+  dummy_symbol->codimension |= attr.codimension;
2985e0
+  dummy_symbol->contiguous |= attr.contiguous;
2985e0
+  dummy_symbol->generic |= attr.generic;
2985e0
+  dummy_symbol->automatic |= attr.automatic;
2985e0
+  dummy_symbol->threadprivate |= attr.threadprivate;
2985e0
+  dummy_symbol->omp_declare_target |= attr.omp_declare_target;
2985e0
+  dummy_symbol->omp_declare_target_link |= attr.omp_declare_target_link;
2985e0
+  dummy_symbol->oacc_declare_copyin |= attr.oacc_declare_copyin;
2985e0
+  dummy_symbol->oacc_declare_create |= attr.oacc_declare_create;
2985e0
+  dummy_symbol->oacc_declare_deviceptr |= attr.oacc_declare_deviceptr;
2985e0
+  dummy_symbol->oacc_declare_device_resident
2985e0
+    |= attr.oacc_declare_device_resident;
2985e0
+
2985e0
+  /* Not strictly correct, but probably close enough.  */
2985e0
+  if (attr.save > dummy_symbol->save)
2985e0
+    dummy_symbol->save = attr.save;
2985e0
+  if (attr.intent > dummy_symbol->intent)
2985e0
+    dummy_symbol->intent = attr.intent;
2985e0
+  if (attr.access > dummy_symbol->access)
2985e0
+    dummy_symbol->access = attr.access;
2985e0
+}
2985e0
 
2985e0
 /* Given a segment element, search through the equivalence lists for unused
2985e0
    conditions that involve the symbol.  Add these rules to the segment.  */
2985e0
@@ -966,8 +1021,11 @@ find_equivalence (segment_info *n)
2985e0
 
2985e0
       /* Search the equivalence list, including the root (first) element
2985e0
          for the symbol that owns the segment.  */
2985e0
+      symbol_attribute dummy_symbol;
2985e0
+      memset (&dummy_symbol, 0, sizeof (dummy_symbol));
2985e0
       for (e2 = e1; e2; e2 = e2->eq)
2985e0
 	{
2985e0
+	  accumulate_equivalence_attributes (&dummy_symbol, e2);
2985e0
 	  if (!e2->used && e2->expr->symtree->n.sym == n->sym)
2985e0
 	    {
2985e0
 	      eq = e2;
2985e0
@@ -975,6 +1033,8 @@ find_equivalence (segment_info *n)
2985e0
 	    }
2985e0
 	}
2985e0
 
2985e0
+      check_conflict (&dummy_symbol, e1->expr->symtree->name, &e1->expr->where);
2985e0
+
2985e0
       /* Go to the next root element.  */
2985e0
       if (eq == NULL)
2985e0
 	continue;
2985e0
diff -Nrcp gcc-8.2.1-20180801/gcc/fortran/trans-common.c save/gcc/fortran/trans-common.c
2985e0
*** a/gcc/fortran/trans-common.c	2018-08-14 18:17:28.000000000 -0400
2985e0
--- b/gcc/fortran/trans-common.c	2018-08-14 17:57:51.000000000 -0400
2985e0
*************** build_field (segment_info *h, tree union
2985e0
*** 339,345 ****
2985e0
  /* Get storage for local equivalence.  */
2985e0
  
2985e0
  static tree
2985e0
! build_equiv_decl (tree union_type, bool is_init, bool is_saved)
2985e0
  {
2985e0
    tree decl;
2985e0
    char name[18];
2985e0
--- 339,345 ----
2985e0
  /* Get storage for local equivalence.  */
2985e0
  
2985e0
  static tree
2985e0
! build_equiv_decl (tree union_type, bool is_init, bool is_saved, bool is_auto)
2985e0
  {
2985e0
    tree decl;
2985e0
    char name[18];
2985e0
*************** build_equiv_decl (tree union_type, bool
2985e0
*** 359,366 ****
2985e0
    DECL_ARTIFICIAL (decl) = 1;
2985e0
    DECL_IGNORED_P (decl) = 1;
2985e0
  
2985e0
!   if (!gfc_can_put_var_on_stack (DECL_SIZE_UNIT (decl))
2985e0
!       || is_saved)
2985e0
      TREE_STATIC (decl) = 1;
2985e0
  
2985e0
    TREE_ADDRESSABLE (decl) = 1;
2985e0
--- 359,367 ----
2985e0
    DECL_ARTIFICIAL (decl) = 1;
2985e0
    DECL_IGNORED_P (decl) = 1;
2985e0
  
2985e0
!   if (!is_auto
2985e0
!       && (!gfc_can_put_var_on_stack (DECL_SIZE_UNIT (decl))
2985e0
! 	  || is_saved))
2985e0
      TREE_STATIC (decl) = 1;
2985e0
  
2985e0
    TREE_ADDRESSABLE (decl) = 1;
2985e0
*************** create_common (gfc_common_head *com, seg
2985e0
*** 611,616 ****
2985e0
--- 612,618 ----
2985e0
    tree decl;
2985e0
    bool is_init = false;
2985e0
    bool is_saved = false;
2985e0
+   bool is_auto = false;
2985e0
  
2985e0
    /* Declare the variables inside the common block.
2985e0
       If the current common block contains any equivalence object, then
2985e0
*************** create_common (gfc_common_head *com, seg
2985e0
*** 654,659 ****
2985e0
--- 656,665 ----
2985e0
        /* Has SAVE attribute.  */
2985e0
        if (s->sym->attr.save)
2985e0
          is_saved = true;
2985e0
+ 
2985e0
+       /* Has AUTOMATIC attribute.  */
2985e0
+       if (s->sym->attr.automatic)
2985e0
+ 	is_auto = true;
2985e0
      }
2985e0
  
2985e0
    finish_record_layout (rli, true);
2985e0
*************** create_common (gfc_common_head *com, seg
2985e0
*** 661,667 ****
2985e0
    if (com)
2985e0
      decl = build_common_decl (com, union_type, is_init);
2985e0
    else
2985e0
!     decl = build_equiv_decl (union_type, is_init, is_saved);
2985e0
  
2985e0
    if (is_init)
2985e0
      {
2985e0
--- 667,673 ----
2985e0
    if (com)
2985e0
      decl = build_common_decl (com, union_type, is_init);
2985e0
    else
2985e0
!     decl = build_equiv_decl (union_type, is_init, is_saved, is_auto);
2985e0
  
2985e0
    if (is_init)
2985e0
      {