projects
/
musl
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
add new syscall numbers from linux v5.2
[musl]
/
arch
/
sh
/
crt_arch.h
diff --git
a/arch/sh/crt_arch.h
b/arch/sh/crt_arch.h
index
b902dcc
..
f341c8f
100644
(file)
--- a/
arch/sh/crt_arch.h
+++ b/
arch/sh/crt_arch.h
@@
-4,27
+4,49
@@
__asm__(
".text \n"
".global " START " \n"
START ": \n"
".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 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"
+" mov.l 4f, r1 \n"
+"5: bsrf r1 \n"
" add r0, r6 \n"
" mov r0, r12 \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 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"
+" 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"
" 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"
#include "fdpic_crt.h"
+#endif
#else
#else
@@
-37,13
+59,14
@@
START ": \n"
" add r0, r5 \n"
" mov r15, r4 \n"
" mov #-16, r0 \n"
" add r0, r5 \n"
" mov r15, r4 \n"
" mov #-16, r0 \n"
-"
and r0, r15
\n"
-"
bsr " START "_c
\n"
-"
nop
\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"
".align 2 \n"
".weak _DYNAMIC \n"
".hidden _DYNAMIC \n"
"1: .long _DYNAMIC-. \n"
+"2: .long " START "_c@PCREL - (3b+4-.) \n"
);
#endif
);
#endif