aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid S. Miller <davem@redhat.com>2002-04-04 15:30:18 -0800
committerDavid S. Miller <davem@gcc.gnu.org>2002-04-04 15:30:18 -0800
commitaa7634ddf73d9f050aaf698afb90abd1d3abf34e (patch)
tree89aa5fe45a6eb1718c2fed44f59d7a8d4ee7968a
parentecc114f755ea1b4c3a218e8c936689d1d8f04188 (diff)
downloadgcc-aa7634ddf73d9f050aaf698afb90abd1d3abf34e.zip
gcc-aa7634ddf73d9f050aaf698afb90abd1d3abf34e.tar.gz
gcc-aa7634ddf73d9f050aaf698afb90abd1d3abf34e.tar.bz2
calls.c (store_one_arg): If ECF_SIBCALL, use tail_call_reg.
2002-04-04 David S. Miller <davem@redhat.com> * calls.c (store_one_arg): If ECF_SIBCALL, use tail_call_reg. From-SVN: r51886
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/calls.c8
2 files changed, 11 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 6c4dc90..eb3270e 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,7 @@
+2002-04-04 David S. Miller <davem@redhat.com>
+
+ * calls.c (store_one_arg): If ECF_SIBCALL, use tail_call_reg.
+
2002-04-04 Richard Henderson <rth@redhat.com>
PR middle-end/5099
diff --git a/gcc/calls.c b/gcc/calls.c
index 197914a..33f4729 100644
--- a/gcc/calls.c
+++ b/gcc/calls.c
@@ -4362,7 +4362,13 @@ store_one_arg (arg, argblock, flags, variable_size, reg_parm_stack_space)
/* If this isn't going to be placed on both the stack and in registers,
set up the register and number of words. */
if (! arg->pass_on_stack)
- reg = arg->reg, partial = arg->partial;
+ {
+ if (flags & ECF_SIBCALL)
+ reg = arg->tail_call_reg;
+ else
+ reg = arg->reg;
+ partial = arg->partial;
+ }
if (reg != 0 && partial == 0)
/* Being passed entirely in a register. We shouldn't be called in