From 6aae6e10ad921dbe4d034777dd9f37043e23bea3 Mon Sep 17 00:00:00 2001 From: law Date: Tue, 28 Mar 2000 21:03:37 +0000 Subject: [PATCH] * sibcall.c (indentify_call_return_value): Find last call in the chain; Allow stack adjustment after function call. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@32791 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/ChangeLog | 3 +++ gcc/sibcall.c | 11 +++++++++-- 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 41f37415ed8..abbdd6c7246 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -25,6 +25,9 @@ Tue Mar 28 11:55:48 2000 Richard Kenner Tue Mar 28 08:29:46 2000 Jan Hubicka + * sibcall.c (indentify_call_return_value): Find last call in the chain; + Allow stack adjustment after function call. + * regmove.c (struct csa_memlist): Make mem field rtx *. (record_one_stack_ref): Accept rtx * instead of rtx as parameter. (try_apply_stack_adjustment): Replace whole MEM rtx. diff --git a/gcc/sibcall.c b/gcc/sibcall.c index 1a3a310388d..34cf5a93348 100644 --- a/gcc/sibcall.c +++ b/gcc/sibcall.c @@ -53,10 +53,12 @@ identify_call_return_value (cp, p_hard_return, p_soft_return) { rtx insn, set, hard, soft; - /* Search forward through the "normal" call sequence to the CALL insn. */ insn = XEXP (cp, 0); - while (GET_CODE (insn) != CALL_INSN) + /* Search backward through the "normal" call sequence to the CALL insn. */ + while (NEXT_INSN (insn)) insn = NEXT_INSN (insn); + while (GET_CODE (insn) != CALL_INSN) + insn = PREV_INSN (insn); /* Assume the pattern is (set (dest) (call ...)), or that the first member of a parallel is. This is the hard return register used @@ -75,6 +77,11 @@ identify_call_return_value (cp, p_hard_return, p_soft_return) if (GET_CODE (hard) != REG) return 0; + /* Stack adjustment done after call may appear here. */ + insn = skip_stack_adjustment (insn); + if (! insn) + return 0; + /* If there's nothing after, there's no soft return value. */ insn = NEXT_INSN (insn); if (! insn) -- 2.11.0