From: mmitchel Date: Mon, 13 Nov 2000 07:00:55 +0000 (+0000) Subject: * function.c (assign_parms): When calling put_var_into_stack, make X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=e43a0ddc69a185376cd41c67315a77ee22481640;p=thirdparty%2Fgcc.git * function.c (assign_parms): When calling put_var_into_stack, make sure that there are no hidden pending sequences. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@37417 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index e27245a8c44f..9ecbca70a354 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2000-11-12 Mark Mitchell + + * function.c (assign_parms): When calling put_var_into_stack, make + sure that there are no hidden pending sequences. + 2000-11-12 Kaveh R. Ghazi * builtins.c (expand_builtin): Handle BUILT_IN_INDEX and diff --git a/gcc/function.c b/gcc/function.c index ece43d3dc9df..bf71b5ac9a8b 100644 --- a/gcc/function.c +++ b/gcc/function.c @@ -4863,7 +4863,19 @@ assign_parms (fndecl) /* If something wants our address, try to use ADDRESSOF. */ if (TREE_ADDRESSABLE (parm)) - put_var_into_stack (parm); + { + /* If we end up putting something into the stack, + fixup_var_refs_insns will need to make a pass over + all the instructions. It looks throughs the pending + sequences -- but it can't see the ones in the + CONVERSION_INSNS, if they're not on the sequence + stack. So, we go back to that sequence, just so that + the fixups will happen. */ + push_to_sequence (conversion_insns); + put_var_into_stack (parm); + conversion_insns = get_insns (); + end_sequence (); + } } else {