aboutsummaryrefslogtreecommitdiff
path: root/gcc/calls.c
diff options
context:
space:
mode:
authorDJ Delorie <dj@redhat.com>2003-05-22 16:54:43 -0400
committerDJ Delorie <dj@gcc.gnu.org>2003-05-22 16:54:43 -0400
commitd892f28886e30a63770448115656dc2026a8c92d (patch)
tree020d537f089bd04e1851dc977a293c0cbadecd4d /gcc/calls.c
parentf59700f9057fd29d8fdcee25efad69e8d9a54dce (diff)
downloadgcc-d892f28886e30a63770448115656dc2026a8c92d.zip
gcc-d892f28886e30a63770448115656dc2026a8c92d.tar.gz
gcc-d892f28886e30a63770448115656dc2026a8c92d.tar.bz2
calls.c (expand_call): If the arg block is going to grow downward...
* calls.c (expand_call): If the arg block is going to grow downward, we need argblock to point to the top of the block, not the bottom. From-SVN: r67099
Diffstat (limited to 'gcc/calls.c')
-rw-r--r--gcc/calls.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/gcc/calls.c b/gcc/calls.c
index 5b4fbc9..a3f2de0 100644
--- a/gcc/calls.c
+++ b/gcc/calls.c
@@ -2828,7 +2828,12 @@ expand_call (exp, target, ignore)
if (needed == 0)
argblock = virtual_outgoing_args_rtx;
else
- argblock = push_block (GEN_INT (needed), 0, 0);
+ {
+ argblock = push_block (GEN_INT (needed), 0, 0);
+#ifdef ARGS_GROW_DOWNWARD
+ argblock = plus_constant (argblock, needed);
+#endif
+ }
/* We only really need to call `copy_to_reg' in the case
where push insns are going to be used to pass ARGBLOCK