diff options
author | David S. Miller <davem@redhat.com> | 2002-04-04 15:30:18 -0800 |
---|---|---|
committer | David S. Miller <davem@gcc.gnu.org> | 2002-04-04 15:30:18 -0800 |
commit | aa7634ddf73d9f050aaf698afb90abd1d3abf34e (patch) | |
tree | 89aa5fe45a6eb1718c2fed44f59d7a8d4ee7968a | |
parent | ecc114f755ea1b4c3a218e8c936689d1d8f04188 (diff) | |
download | gcc-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/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/calls.c | 8 |
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 |