diff options
author | law <law@138bc75d-0d04-0410-961f-82ee72b054a4> | 1997-11-14 14:06:07 +0000 |
---|---|---|
committer | law <law@138bc75d-0d04-0410-961f-82ee72b054a4> | 1997-11-14 14:06:07 +0000 |
commit | a4e41de77b219dd95d8eb2e02657133b80032da1 (patch) | |
tree | e2fb28c342648ac9106c1370ad2af4e6b441d4ec /gcc/calls.c | |
parent | 44e00f80c7d8427e88d26471daaf2c4248ea5615 (diff) | |
download | gcc-a4e41de77b219dd95d8eb2e02657133b80032da1.tar.gz |
* calls.c (expand_call): Handle pcc_struct_value correctly for C++.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@16485 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/calls.c')
-rw-r--r-- | gcc/calls.c | 36 |
1 files changed, 6 insertions, 30 deletions
diff --git a/gcc/calls.c b/gcc/calls.c index a70830ce304..2d94cb6287d 100644 --- a/gcc/calls.c +++ b/gcc/calls.c @@ -2061,36 +2061,12 @@ expand_call (exp, target, ignore) } else if (pcc_struct_value) { - if (target == 0) - { - /* We used leave the value in the location that it is - returned in, but that causes problems if it is used more - than once in one expression. Rather than trying to track - when a copy is required, we always copy when TARGET is - not specified. This calling sequence is only used on - a few machines and TARGET is usually nonzero. */ - if (TYPE_MODE (TREE_TYPE (exp)) == BLKmode) - { - target = assign_stack_temp (BLKmode, - int_size_in_bytes (TREE_TYPE (exp)), - 0); - - MEM_IN_STRUCT_P (target) = AGGREGATE_TYPE_P (TREE_TYPE (exp)); - - /* Save this temp slot around the pop below. */ - preserve_temp_slots (target); - } - else - target = gen_reg_rtx (TYPE_MODE (TREE_TYPE (exp))); - } - - if (TYPE_MODE (TREE_TYPE (exp)) != BLKmode) - emit_move_insn (target, gen_rtx (MEM, TYPE_MODE (TREE_TYPE (exp)), - copy_to_reg (valreg))); - else - emit_block_move (target, gen_rtx (MEM, BLKmode, copy_to_reg (valreg)), - expr_size (exp), - TYPE_ALIGN (TREE_TYPE (exp)) / BITS_PER_UNIT); + /* This is the special C++ case where we need to + know what the true target was. We take care to + never use this value more than once in one expression. */ + target = gen_rtx (MEM, TYPE_MODE (TREE_TYPE (exp)), + copy_to_reg (valreg)); + MEM_IN_STRUCT_P (target) = AGGREGATE_TYPE_P (TREE_TYPE (exp)); } /* Handle calls that return values in multiple non-contiguous locations. The Irix 6 ABI has examples of this. */ |