Commit 8ebec1a5 by Jakub Jelinek Committed by Jakub Jelinek

re PR target/35366 (gfortran.dg/equiv_7.f90 fails with -m64 -Os on powerpc-apple-darwin9)

	PR target/35366
	* expr.c (expand_expr_addr_expr_1): If EXP needs bigger alignment
	than INNER and INNER is a constant, forcibly align INNER as much
	as needed.

From-SVN: r141782
parent 0d6872cb
2008-11-12 Jakub Jelinek <jakub@redhat.com>
PR target/35366
* expr.c (expand_expr_addr_expr_1): If EXP needs bigger alignment
than INNER and INNER is a constant, forcibly align INNER as much
as needed.
2008-11-11 Richard Sandiford <rdsandiford@googlemail.com> 2008-11-11 Richard Sandiford <rdsandiford@googlemail.com>
* cse.c (fold_rtx): Remove redundant gen_rtx_CONST. * cse.c (fold_rtx): Remove redundant gen_rtx_CONST.
......
...@@ -6862,6 +6862,16 @@ expand_expr_addr_expr_1 (tree exp, rtx target, enum machine_mode tmode, ...@@ -6862,6 +6862,16 @@ expand_expr_addr_expr_1 (tree exp, rtx target, enum machine_mode tmode,
gcc_assert (inner != exp); gcc_assert (inner != exp);
subtarget = offset || bitpos ? NULL_RTX : target; subtarget = offset || bitpos ? NULL_RTX : target;
/* For VIEW_CONVERT_EXPR, where the outer alignment is bigger than
inner alignment, force the inner to be sufficiently aligned. */
if (CONSTANT_CLASS_P (inner)
&& TYPE_ALIGN (TREE_TYPE (inner)) < TYPE_ALIGN (TREE_TYPE (exp)))
{
inner = copy_node (inner);
TREE_TYPE (inner) = copy_node (TREE_TYPE (inner));
TYPE_ALIGN (TREE_TYPE (inner)) = TYPE_ALIGN (TREE_TYPE (exp));
TYPE_USER_ALIGN (TREE_TYPE (inner)) = 1;
}
result = expand_expr_addr_expr_1 (inner, subtarget, tmode, modifier); result = expand_expr_addr_expr_1 (inner, subtarget, tmode, modifier);
if (offset) if (offset)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment