diff options
author | DJ Delorie <dj@redhat.com> | 2003-05-22 16:54:43 -0400 |
---|---|---|
committer | DJ Delorie <dj@gcc.gnu.org> | 2003-05-22 16:54:43 -0400 |
commit | d892f28886e30a63770448115656dc2026a8c92d (patch) | |
tree | 020d537f089bd04e1851dc977a293c0cbadecd4d /gcc/calls.c | |
parent | f59700f9057fd29d8fdcee25efad69e8d9a54dce (diff) | |
download | gcc-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.c | 7 |
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 |