Commit 91804752 by Eric Botcazou Committed by Eric Botcazou

re PR middle-end/17793 (Ada bootstrap failure)

	PR middle-end/17793
	* gimplify.c (gimplify_addr_expr) <VIEW_CONVERT_EXPR>: Look
	through the operand if it is a useless type conversion.

From-SVN: r89488
parent 757f86d6
2004-10-23 Eric Botcazou <ebotcazou@libertysurf.fr>
PR middle-end/17793
* gimplify.c (gimplify_addr_expr) <VIEW_CONVERT_EXPR>: Look
through the operand if it is a useless type conversion.
2004-10-23 Ben Elliston <bje@au.ibm.com> 2004-10-23 Ben Elliston <bje@au.ibm.com>
* cfg.c (remove_edge): Use VEC_unordered_remove. * cfg.c (remove_edge): Use VEC_unordered_remove.
......
...@@ -3093,6 +3093,13 @@ gimplify_addr_expr (tree *expr_p, tree *pre_p, tree *post_p) ...@@ -3093,6 +3093,13 @@ gimplify_addr_expr (tree *expr_p, tree *pre_p, tree *post_p)
??? The interactions of VIEW_CONVERT_EXPR and aliasing is not at ??? The interactions of VIEW_CONVERT_EXPR and aliasing is not at
all clear. The impact of this transformation is even less clear. */ all clear. The impact of this transformation is even less clear. */
/* If the operand is a useless conversion, look through it. Doing so
guarantees that the ADDR_EXPR and its operand will remain of the
same type. */
if (tree_ssa_useless_type_conversion (TREE_OPERAND (op0, 0)))
op0 = TREE_OPERAND (op0, 0);
*expr_p = fold_convert (TREE_TYPE (expr), *expr_p = fold_convert (TREE_TYPE (expr),
build_fold_addr_expr (TREE_OPERAND (op0, 0))); build_fold_addr_expr (TREE_OPERAND (op0, 0)));
ret = GS_OK; ret = GS_OK;
......
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