From c5c4370fb958ac481193b8b3996fcec9c37feb45 Mon Sep 17 00:00:00 2001 From: dje Date: Mon, 16 Nov 1998 15:00:10 +0000 Subject: [PATCH] * rs6000.c (output_mi_thunk): Improve test for local branch. * rs6000.c (output_mi_thunk): Correct test for aggregate values. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@23676 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/ChangeLog | 10 +++++++++- gcc/config/rs6000/rs6000.c | 4 ++-- 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index af1367a..e895e95 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,11 @@ +Mon Nov 16 17:56:07 1998 David Edelsohn + + * rs6000.c (output_mi_thunk): Improve test for local branch. + +Mon Nov 16 17:56:07 1998 Franz Sirl + + * rs6000.c (output_mi_thunk): Correct test for aggregate values. + Mon Nov 16 21:02:52 1998 J"orn Rennecke * reload1.c (reload_reg_free_before_p): Delete. @@ -5350,7 +5358,7 @@ Sun Aug 16 01:53:21 1998 Richard Henderson * reload.c (find_equiv_reg): Reject equivalences separated by a volatile instruction. -Sun Aug 16 00:21:44 1998 Franz Sirl +Sun Aug 16 00:21:44 1998 Franz Sirl * rs6000/linux.h (CPP_OS_DEFAULT_SPEC): Define. diff --git a/gcc/config/rs6000/rs6000.c b/gcc/config/rs6000/rs6000.c index 9ae69e8..6f96bf1 100644 --- a/gcc/config/rs6000/rs6000.c +++ b/gcc/config/rs6000/rs6000.c @@ -4474,7 +4474,7 @@ output_mi_thunk (file, thunk_fndecl, delta, function) int delta; tree function; { - char *this_reg = reg_names[ aggregate_value_p (TREE_TYPE (function)) ? 3 : 4 ]; + char *this_reg = reg_names[ aggregate_value_p (TREE_TYPE (TREE_TYPE (function))) ? 4 : 3 ]; char *r0 = reg_names[0]; char *sp = reg_names[1]; char *toc = reg_names[2]; @@ -4559,7 +4559,7 @@ output_mi_thunk (file, thunk_fndecl, delta, function) fprintf (file, "\n"); #else - if (TREE_ASM_WRITTEN (function) + if (current_file_function_operand (XEXP (DECL_RTL (function), 0)) && !lookup_attribute ("longcall", TYPE_ATTRIBUTES (TREE_TYPE (function)))) { fprintf (file, "\tb %s", prefix); -- 2.7.4