summaryrefslogtreecommitdiff
path: root/gcc/gimplify.c
diff options
context:
space:
mode:
authorjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>2004-06-11 03:26:31 +0000
committerjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>2004-06-11 03:26:31 +0000
commitd949e32463741808a32d4a49ddc7362033949e1f (patch)
tree286dfd310c69cb69eb51a600c9b4516f6e965fb7 /gcc/gimplify.c
parentbd1ec5136ae88e2f2528fdb71aad703b7836eb55 (diff)
downloadgcc-d949e32463741808a32d4a49ddc7362033949e1f.tar.gz
* gimplify.c (gimplify_modify_expr): Don't force a temporary
of an aggregate_value_p type. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@82959 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/gimplify.c')
-rw-r--r--gcc/gimplify.c16
1 files changed, 10 insertions, 6 deletions
diff --git a/gcc/gimplify.c b/gcc/gimplify.c
index c25a89171b3..a4b9c702e28 100644
--- a/gcc/gimplify.c
+++ b/gcc/gimplify.c
@@ -2493,12 +2493,16 @@ gimplify_modify_expr (tree *expr_p, tree *pre_p, tree *post_p, bool want_value)
FIXME this should be handled by the is_gimple_rhs predicate. */
- if (TREE_CODE (*from_p) == CALL_EXPR
- || (flag_non_call_exceptions && tree_could_trap_p (*from_p))
- /* If we're dealing with a renamable type, either source or dest
- must be a renamed variable. */
- || (is_gimple_reg_type (TREE_TYPE (*from_p))
- && !is_gimple_reg (*to_p)))
+ if (aggregate_value_p (TREE_TYPE (*from_p), NULL_TREE))
+ /* Don't force a temp of a large aggregate type; the copy could be
+ arbitrarily expensive. Instead we will generate a V_MAY_DEF for
+ the assignment. */;
+ else if (TREE_CODE (*from_p) == CALL_EXPR
+ || (flag_non_call_exceptions && tree_could_trap_p (*from_p))
+ /* If we're dealing with a renamable type, either source or dest
+ must be a renamed variable. */
+ || (is_gimple_reg_type (TREE_TYPE (*from_p))
+ && !is_gimple_reg (*to_p)))
gimplify_expr (from_p, pre_p, post_p, is_gimple_val, fb_rvalue);
/* If the value being copied is of variable width, expose the length