new dlstart stage-2 chaining for mips
[musl] / arch / sh / crt_arch.h
1 #ifdef __SH_FDPIC__
2
3 __asm__(
4 ".text \n"
5 ".global " START " \n"
6 START ": \n"
7 "       mov r8, r4 \n"
8 "       mova 1f, r0 \n"
9 "       mov.l 1f, r5 \n"
10 "       mov.l 1f+4, r6 \n"
11 "       add r0, r5 \n"
12 "       bsr __fdpic_fixup \n"
13 "        add r0, r6 \n"
14 "       mov r0, r12 \n"
15 "       mov r15, r4 \n"
16 "       mov #-16, r0 \n"
17 "       bsr " START "_c \n"
18 "        and r0, r15 \n"
19 ".align 2 \n"
20 "1:     .long __ROFIXUP_LIST__@PCREL \n"
21 "       .long __ROFIXUP_END__@PCREL + 4 \n"
22 );
23
24 #include "fdpic_crt.h"
25
26 #else
27
28 __asm__(
29 ".text \n"
30 ".global " START " \n"
31 START ": \n"
32 "       mova 1f, r0 \n"
33 "       mov.l 1f, r5 \n"
34 "       add r0, r5 \n"
35 "       mov r15, r4 \n"
36 "       mov #-16, r0 \n"
37 "       and r0, r15 \n"
38 "       bsr " START "_c \n"
39 "       nop \n"
40 ".align 2 \n"
41 ".weak _DYNAMIC \n"
42 ".hidden _DYNAMIC \n"
43 "1:     .long _DYNAMIC-. \n"
44 );
45
46 #endif
47
48 /* used by gcc for switching the FPU between single and double precision */
49 #ifdef SHARED
50 __attribute__((__visibility__("hidden")))
51 #endif
52 const unsigned long __fpscr_values[2] = { 0, 0x80000 };