keep user-provided CFLAGS/LDFLAGS separate from those added by configure
[musl] / arch / sh / crt_arch.h
index e9745f9..948bcb7 100644 (file)
@@ -4,6 +4,19 @@ __asm__(
 ".text \n"
 ".global " START " \n"
 START ": \n"
+"      tst r8, r8 \n"
+"      bf 1f \n"
+"      mov #68, r3 \n"
+"      add r3, r3 \n"
+"      mov #8, r4 \n"
+"      swap.w r4, r4 \n"
+"      trapa #31 \n"
+"      nop \n"
+"      nop \n"
+"      nop \n"
+"      nop \n"
+"1:    nop \n"
+#ifndef SHARED
 "      mov r8, r4 \n"
 "      mova 1f, r0 \n"
 "      mov.l 1f, r5 \n"
@@ -12,7 +25,11 @@ START ": \n"
 "      bsr __fdpic_fixup \n"
 "       add r0, r6 \n"
 "      mov r0, r12 \n"
+#endif
+"      mov r10, r5 \n"
 "      mov r15, r4 \n"
+"      mov.l r9, @-r15 \n"
+"      mov.l r8, @-r15 \n"
 "      mov #-16, r0 \n"
 "      bsr " START "_c \n"
 "       and r0, r15 \n"
@@ -21,7 +38,9 @@ START ": \n"
 "      .long __ROFIXUP_END__@PCREL + 4 \n"
 );
 
+#ifndef SHARED
 #include "fdpic_crt.h"
+#endif
 
 #else