X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=arch%2Fsh%2Fcrt_arch.h;h=e9745f9b5aa5ed3b27d300e5d1b58d062093e022;hb=cd7159e7be73451befedce2e9dfd9f6a4c3b21f0;hp=f8907108b6388f4d9abe72acbd4223dd7813c561;hpb=63caf1d207d143fe405bbe0cda9aac8deca1171a;p=musl diff --git a/arch/sh/crt_arch.h b/arch/sh/crt_arch.h index f8907108..e9745f9b 100644 --- a/arch/sh/crt_arch.h +++ b/arch/sh/crt_arch.h @@ -1,3 +1,30 @@ +#ifdef __SH_FDPIC__ + +__asm__( +".text \n" +".global " START " \n" +START ": \n" +" mov r8, r4 \n" +" mova 1f, r0 \n" +" mov.l 1f, r5 \n" +" mov.l 1f+4, r6 \n" +" add r0, r5 \n" +" bsr __fdpic_fixup \n" +" add r0, r6 \n" +" mov r0, r12 \n" +" mov r15, r4 \n" +" mov #-16, r0 \n" +" bsr " START "_c \n" +" and r0, r15 \n" +".align 2 \n" +"1: .long __ROFIXUP_LIST__@PCREL \n" +" .long __ROFIXUP_END__@PCREL + 4 \n" +); + +#include "fdpic_crt.h" + +#else + __asm__( ".text \n" ".global " START " \n" @@ -16,6 +43,8 @@ START ": \n" "1: .long _DYNAMIC-. \n" ); +#endif + /* used by gcc for switching the FPU between single and double precision */ #ifdef SHARED __attribute__((__visibility__("hidden")))