From 04d6fcf87b9e8916d9eda67e9875d6f477a47c12 Mon Sep 17 00:00:00 2001 From: davem Date: Thu, 4 Apr 2002 23:30:18 +0000 Subject: [PATCH] 2002-04-04 David S. Miller * calls.c (store_one_arg): If ECF_SIBCALL, use tail_call_reg. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@51886 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/ChangeLog | 4 ++++ gcc/calls.c | 8 +++++++- 2 files changed, 11 insertions(+), 1 deletion(-) 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 + + * calls.c (store_one_arg): If ECF_SIBCALL, use tail_call_reg. + 2002-04-04 Richard Henderson 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 -- 2.7.4