Remove last use of expr_align
authorEric Botcazou <ebotcazou@gcc.gnu.org>
Sat, 9 May 2020 19:37:13 +0000 (21:37 +0200)
committerEric Botcazou <ebotcazou@gcc.gnu.org>
Sat, 9 May 2020 20:14:04 +0000 (22:14 +0200)
It was in the ada/gcc-interface repository and is outdated.

* tree.h (expr_align): Delete.
* tree.c (expr_align): Likewise.
ada/
* gcc-interface/utils2.c: Include builtins.h.
(known_alignment) <ADDR_EXPR>: Use DECL_ALIGN for DECL_P operands
and get_object_alignment for the rest.

gcc/ChangeLog
gcc/ada/ChangeLog
gcc/ada/gcc-interface/utils2.c
gcc/tree.c
gcc/tree.h

index 178973f0e734673ca4eb5cbf3bf0caceeef61351..cff8ea3f95abdcdab34cbc8c288fdedd1ba352b1 100644 (file)
@@ -1,3 +1,8 @@
+2020-05-09  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree.h (expr_align): Delete.
+       * tree.c (expr_align): Likewise.
+
 2020-05-09  Hans-Peter Nilsson  <hp@axis.com>
 
        * resource.c (init_resource_info): Filter-out TARGET_FLAGS_REGNUM
index 35d111401e2923a33695300690f2244b2f010af1..0c1c265c8ebfad2dfa8ce1d02893d6407b32ff52 100644 (file)
@@ -1,3 +1,9 @@
+2020-05-09  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * gcc-interface/utils2.c: Include builtins.h.
+       (known_alignment) <ADDR_EXPR>: Use DECL_ALIGN for DECL_P operands
+       and get_object_alignment for the rest.
+
 2020-05-08  Eric Botcazou  <ebotcazou@adacore.com>
 
        * gcc-interface/decl.c (gnat_to_gnu_entity) <E_Variable>: Force at
index 6ff1372899c006beecbc445f94ce84fef2f6e20f..30d08f508965a6965ba144da1007e202e232cbf0 100644 (file)
@@ -32,6 +32,7 @@
 #include "alias.h"
 #include "tree.h"
 #include "inchash.h"
+#include "builtins.h"
 #include "fold-const.h"
 #include "stor-layout.h"
 #include "stringpool.h"
@@ -167,7 +168,10 @@ known_alignment (tree exp)
       break;
 
     case ADDR_EXPR:
-      this_alignment = expr_align (TREE_OPERAND (exp, 0));
+      if (DECL_P (TREE_OPERAND (exp, 0)))
+       this_alignment = DECL_ALIGN (TREE_OPERAND (exp, 0));
+      else
+       this_alignment = get_object_alignment (TREE_OPERAND (exp, 0));
       break;
 
     case CALL_EXPR:
index 397474900ff9191c9a18ca473479304b8109d8a3..5b7d3fddbcbcc1f4814677f99e7a4c25b55fd53e 100644 (file)
@@ -3351,51 +3351,6 @@ int_byte_position (const_tree field)
   return tree_to_shwi (byte_position (field));
 }
 \f
-/* Return the strictest alignment, in bits, that T is known to have.  */
-
-unsigned int
-expr_align (const_tree t)
-{
-  unsigned int align0, align1;
-
-  switch (TREE_CODE (t))
-    {
-    CASE_CONVERT:  case NON_LVALUE_EXPR:
-      /* If we have conversions, we know that the alignment of the
-        object must meet each of the alignments of the types.  */
-      align0 = expr_align (TREE_OPERAND (t, 0));
-      align1 = TYPE_ALIGN (TREE_TYPE (t));
-      return MAX (align0, align1);
-
-    case SAVE_EXPR:         case COMPOUND_EXPR:       case MODIFY_EXPR:
-    case INIT_EXPR:         case TARGET_EXPR:         case WITH_CLEANUP_EXPR:
-    case CLEANUP_POINT_EXPR:
-      /* These don't change the alignment of an object.  */
-      return expr_align (TREE_OPERAND (t, 0));
-
-    case COND_EXPR:
-      /* The best we can do is say that the alignment is the least aligned
-        of the two arms.  */
-      align0 = expr_align (TREE_OPERAND (t, 1));
-      align1 = expr_align (TREE_OPERAND (t, 2));
-      return MIN (align0, align1);
-
-      /* FIXME: LABEL_DECL and CONST_DECL never have DECL_ALIGN set
-        meaningfully, it's always 1.  */
-    case LABEL_DECL:     case CONST_DECL:
-    case VAR_DECL:       case PARM_DECL:   case RESULT_DECL:
-    case FUNCTION_DECL:
-      gcc_assert (DECL_ALIGN (t) != 0);
-      return DECL_ALIGN (t);
-
-    default:
-      break;
-    }
-
-  /* Otherwise take the alignment from that of the type.  */
-  return TYPE_ALIGN (TREE_TYPE (t));
-}
-\f
 /* Return, as a tree node, the number of elements for TYPE (which is an
    ARRAY_TYPE) minus one. This counts only elements of the top array.  */
 
index c51c4b651d40a5ddf074514722701ac8ce60ca93..4644d6616d91229fde7035c5fc5f50bf170e67b8 100644 (file)
@@ -4641,7 +4641,6 @@ extern hashval_t type_hash_canon_hash (tree);
 extern tree type_hash_canon (unsigned int, tree);
 
 extern tree convert (tree, tree);
-extern unsigned int expr_align (const_tree);
 extern tree size_in_bytes_loc (location_t, const_tree);
 inline tree
 size_in_bytes (const_tree t)