aboutsummaryrefslogtreecommitdiff
path: root/gcc/builtins.c
diff options
context:
space:
mode:
authorBernd Edlinger <edlinger@gcc.gnu.org>2013-11-27 16:33:01 +0000
committerBernd Edlinger <edlinger@gcc.gnu.org>2013-11-27 16:33:01 +0000
commitb3ecff82d7f193033d98d04124114aa57c2adba3 (patch)
tree57109bd0c5a05fb6134524e9eba3e9890ae43804 /gcc/builtins.c
parent36db5f30004bdf03cde1fbd0e1355ff50e1b91cc (diff)
downloadgcc-b3ecff82d7f193033d98d04124114aa57c2adba3.zip
gcc-b3ecff82d7f193033d98d04124114aa57c2adba3.tar.gz
gcc-b3ecff82d7f193033d98d04124114aa57c2adba3.tar.bz2
2013-11-27 Bernd Edlinger <bernd.edlinger@hotmail.de>
reverted r205398 on request: Remove parameter keep_aligning from get_inner_reference. From-SVN: r205452
Diffstat (limited to 'gcc/builtins.c')
-rw-r--r--gcc/builtins.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/gcc/builtins.c b/gcc/builtins.c
index 3f03b01..d2248ea 100644
--- a/gcc/builtins.c
+++ b/gcc/builtins.c
@@ -329,7 +329,7 @@ get_object_alignment_2 (tree exp, unsigned int *alignp,
/* Get the innermost object and the constant (bitpos) and possibly
variable (offset) offset of the access. */
exp = get_inner_reference (exp, &bitsize, &bitpos, &offset,
- &mode, &unsignedp, &volatilep);
+ &mode, &unsignedp, &volatilep, true);
/* Extract alignment information from the innermost object and
possibly adjust bitpos and offset. */
@@ -360,6 +360,10 @@ get_object_alignment_2 (tree exp, unsigned int *alignp,
align = DECL_ALIGN (exp);
known_alignment = true;
}
+ else if (TREE_CODE (exp) == VIEW_CONVERT_EXPR)
+ {
+ align = TYPE_ALIGN (TREE_TYPE (exp));
+ }
else if (TREE_CODE (exp) == INDIRECT_REF
|| TREE_CODE (exp) == MEM_REF
|| TREE_CODE (exp) == TARGET_MEM_REF)