From 194faace59fd10e2db5a894f068b1c7f3311a9cd Mon Sep 17 00:00:00 2001 From: Richard Henderson Date: Mon, 29 Dec 1997 16:02:54 -0800 Subject: [PATCH] sparc.h (ASM_OUTPUT_MI_THUNK): Move %o7 through %g1 instead of save+restore. * sparc.h (ASM_OUTPUT_MI_THUNK): Move %o7 through %g1 instead of save+restore. Fix pic+big_offset delay slot. Use "pic" case for unix always, since we want to be able to thunk to functions in a shared library from an application. From-SVN: r17262 --- gcc/ChangeLog | 7 +++++++ gcc/config/sparc/sparc.h | 14 +++++++++----- 2 files changed, 16 insertions(+), 5 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index c619c03b371..b2043d1ac9a 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +Tue Dec 30 00:04:49 1997 Richard Henderson + + * sparc.h (ASM_OUTPUT_MI_THUNK): Move %o7 through %g1 instead of + save+restore. Fix pic+big_offset delay slot. Use "pic" case for + unix always, since we want to be able to thunk to functions in a + shared library from an application. + Mon Dec 29 14:37:31 1997 Ian Lance Taylor * mips/t-ecoff (CROSS_LIBGCC1): Define to libgcc1-asm.a. diff --git a/gcc/config/sparc/sparc.h b/gcc/config/sparc/sparc.h index e87058cc33f..2cc8b95a3d5 100644 --- a/gcc/config/sparc/sparc.h +++ b/gcc/config/sparc/sparc.h @@ -3017,11 +3017,15 @@ do { \ int big_delta = (DELTA) >= 4096 || (DELTA) < -4096; \ if (big_delta) \ fprintf (FILE, "\tset %d,%%g1\n\tadd %%o0,%%g1,%%o0\n", (DELTA)); \ - if (flag_pic) \ + /* Don't use the jmp solution unless we know the target is local to \ + the application or shared object. \ + XXX: Wimp out and don't actually check anything except if this is \ + an embedded target where we assume there are no shared libs. */ \ + if (!TARGET_CM_EMBMEDANY || flag_pic) \ { \ if (! big_delta) \ fprintf (FILE, "\tadd %%o0,%d,%%o0\n", DELTA); \ - fprintf (FILE, "\tsave %%sp,-112,%%sp\n"); \ + fprintf (FILE, "\tmov %%o7,%%g1\n"); \ fprintf (FILE, "\tcall "); \ assemble_name \ (FILE, IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (FUNCTION))); \ @@ -3044,10 +3048,10 @@ do { \ (FILE, IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (FUNCTION))); \ fprintf (FILE, ")\n"); \ } \ - if (big_delta) \ + if (!TARGET_CM_EMBMEDANY || flag_pic) \ + fprintf (FILE, "\tmov %%g1,%%o7\n"); \ + else if (big_delta) \ fprintf (FILE, "\tnop\n"); \ - else if (flag_pic) \ - fprintf (FILE, "\trestore\n"); \ else \ fprintf (FILE, "\tadd %%o0,%d,%%o0\n", DELTA); \ } while (0)