From: David S. Miller Date: Thu, 4 Apr 2002 23:30:18 +0000 (-0800) Subject: calls.c (store_one_arg): If ECF_SIBCALL, use tail_call_reg. X-Git-Tag: releases/gcc-3.3.0~5884 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=aa7634ddf73d9f050aaf698afb90abd1d3abf34e;p=thirdparty%2Fgcc.git calls.c (store_one_arg): If ECF_SIBCALL, use tail_call_reg. 2002-04-04 David S. Miller * calls.c (store_one_arg): If ECF_SIBCALL, use tail_call_reg. From-SVN: r51886 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 6c4dc907035d..eb3270e925f1 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 197914a9e7a6..33f47296e215 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