diff options
author | jason <jason@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-06-11 03:26:31 +0000 |
---|---|---|
committer | jason <jason@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-06-11 03:26:31 +0000 |
commit | d949e32463741808a32d4a49ddc7362033949e1f (patch) | |
tree | 286dfd310c69cb69eb51a600c9b4516f6e965fb7 /gcc/gimplify.c | |
parent | bd1ec5136ae88e2f2528fdb71aad703b7836eb55 (diff) | |
download | gcc-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.c | 16 |
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 |