expr.c (expand_expr): When testing for unaligned objects...
authorEric Botcazou <ebotcazou@adacore.com>
Thu, 29 Jun 2017 19:21:25 +0000 (19:21 +0000)
committerEric Botcazou <ebotcazou@gcc.gnu.org>
Thu, 29 Jun 2017 19:21:25 +0000 (19:21 +0000)
* expr.c (expand_expr) <normal_inner_ref>: When testing for unaligned
objects, take into account only the alignment of 'op0' and 'mode1' if
'op0' is a MEM.

From-SVN: r249811

gcc/ChangeLog
gcc/expr.c

index 079c674a7ce674b22b44a01178ddd6332cea32f1..4f8868bc8bea68dbb49894105d623243c5b01e00 100644 (file)
@@ -1,3 +1,9 @@
+2017-06-29  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * expr.c (expand_expr) <normal_inner_ref>: When testing for unaligned
+       objects, take into account only the alignment of 'op0' and 'mode1' if
+       'op0' is a MEM.
+
 2017-06-29  Steve Ellcey  <sellcey@cavium.com>
 
        * ccmp.c (ccmp_tree_comparison_p): New function.
index 0a52a3d7209bcceb705e226d77f13792ce417b01..0e8216ba7d00652ff0fe8558aacacf5783631c07 100644 (file)
@@ -10639,11 +10639,11 @@ expand_expr_real_1 (tree exp, rtx target, machine_mode tmode,
            /* If the field isn't aligned enough to fetch as a memref,
               fetch it as a bit field.  */
            || (mode1 != BLKmode
-               && (((TYPE_ALIGN (TREE_TYPE (tem)) < GET_MODE_ALIGNMENT (mode)
-                     || (bitpos % GET_MODE_ALIGNMENT (mode) != 0)
-                     || (MEM_P (op0)
-                         && (MEM_ALIGN (op0) < GET_MODE_ALIGNMENT (mode1)
-                             || (bitpos % GET_MODE_ALIGNMENT (mode1) != 0))))
+               && (((MEM_P (op0)
+                     ? MEM_ALIGN (op0) < GET_MODE_ALIGNMENT (mode1)
+                       || (bitpos % GET_MODE_ALIGNMENT (mode1) != 0)
+                     : TYPE_ALIGN (TREE_TYPE (tem)) < GET_MODE_ALIGNMENT (mode)
+                       || (bitpos % GET_MODE_ALIGNMENT (mode) != 0))
                     && modifier != EXPAND_MEMORY
                     && ((modifier == EXPAND_CONST_ADDRESS
                          || modifier == EXPAND_INITIALIZER)