From e87b62d96da654acfeea3765d1f046a7186d804c Mon Sep 17 00:00:00 2001 From: Jeffrey A Law Date: Tue, 19 Oct 1999 08:05:40 +0000 Subject: [PATCH] reg-stack.c (stack_result): Aggregates are not returned in stack registers. * reg-stack.c (stack_result): Aggregates are not returned in stack registers. From-SVN: r30079 --- gcc/ChangeLog | 5 +++++ gcc/reg-stack.c | 10 +++++++++- 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 3bddf0d4bdbf..59c2ada88ae6 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +Tue Oct 19 02:03:00 1999 Jeffrey A Law (law@cygnus.com) + + * reg-stack.c (stack_result): Aggregates are not returned in + stack registers. + Mon Oct 18 01:41:35 1999 Jeffrey A Law (law@cygnus.com) * combine.c (get_last_value): If the last set of a register diff --git a/gcc/reg-stack.c b/gcc/reg-stack.c index dd4a87e697cd..42caefa0a42b 100644 --- a/gcc/reg-stack.c +++ b/gcc/reg-stack.c @@ -1186,8 +1186,16 @@ static rtx stack_result (decl) tree decl; { - rtx result = DECL_RTL (DECL_RESULT (decl)); + rtx result; + /* If the value is supposed to be returned in memory, then clearly + it is not returned in a stack register. */ + if (aggregate_value_p (DECL_RESULT (decl))) + return 0; + + result = DECL_RTL (DECL_RESULT (decl)); + /* ?!? What is this code supposed to do? Can this code actually + trigger if we kick out aggregates above? */ if (result != 0 && ! (GET_CODE (result) == REG && REGNO (result) < FIRST_PSEUDO_REGISTER)) -- 2.47.2