getaddrinfo: add EAI_NODATA error code to distinguish NODATA vs NxDomain
[musl] / arch / sh / crt_arch.h
index 5fd39fc..f341c8f 100644 (file)
@@ -1,12 +1,78 @@
-__asm__("\
-.global _start \n\
-_start: \n\
-       mov r15, r4 \n\
-       mov #-16, r0 \n\
-       and r0, r15 \n\
-       bsr __cstart \n\
-       nop \n\
-");
+#ifdef __SH_FDPIC__
+
+__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"
+"      mov.l 1f+4, r6 \n"
+"      add r0, r5 \n"
+"      mov.l 4f, r1 \n"
+"5:    bsrf r1 \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"
+"      mov.l 2f, r1 \n"
+"3:    bsrf r1 \n"
+"       and r0, r15 \n"
+".align 2 \n"
+"1:    .long __ROFIXUP_LIST__@PCREL \n"
+"      .long __ROFIXUP_END__@PCREL + 4 \n"
+"2:    .long " START "_c@PCREL - (3b+4-.) \n"
+#ifndef SHARED
+"4:    .long __fdpic_fixup@PCREL - (5b+4-.) \n"
+#endif
+);
+
+#ifndef SHARED
+#include "fdpic_crt.h"
+#endif
+
+#else
+
+__asm__(
+".text \n"
+".global " START " \n"
+START ": \n"
+"      mova 1f, r0 \n"
+"      mov.l 1f, r5 \n"
+"      add r0, r5 \n"
+"      mov r15, r4 \n"
+"      mov #-16, r0 \n"
+"      mov.l 2f, r1 \n"
+"3:    bsrf r1 \n"
+"       and r0, r15 \n"
+".align 2 \n"
+".weak _DYNAMIC \n"
+".hidden _DYNAMIC \n"
+"1:    .long _DYNAMIC-. \n"
+"2:    .long " START "_c@PCREL - (3b+4-.) \n"
+);
+
+#endif
 
 /* used by gcc for switching the FPU between single and double precision */
+#ifdef SHARED
+__attribute__((__visibility__("hidden")))
+#endif
 const unsigned long __fpscr_values[2] = { 0, 0x80000 };