summaryrefslogtreecommitdiff
path: root/arch/sh
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2015-11-02 18:11:36 -0500
committerRich Felker <dalias@aerifal.cx>2015-11-02 18:11:36 -0500
commit4fcb48275adbe1959852d298425e2da610708975 (patch)
treec9c1296d9b5b7e4d17e109fc38e717ef7ba09ad3 /arch/sh
parent4cd8b4725907651f329e2f96d428c4e3521643f8 (diff)
downloadmusl-4fcb48275adbe1959852d298425e2da610708975.tar.gz
musl-4fcb48275adbe1959852d298425e2da610708975.tar.bz2
musl-4fcb48275adbe1959852d298425e2da610708975.tar.xz
musl-4fcb48275adbe1959852d298425e2da610708975.zip
generalize sh entry point asm not to assume call dests fit in 12 bits
this assumption is borderline-unsafe to begin with, and fails badly with -ffunction-sections since the linker can move the callee arbitrarily far away when it lies in a different section.
Diffstat (limited to 'arch/sh')
-rw-r--r--arch/sh/crt_arch.h17
1 files changed, 12 insertions, 5 deletions
diff --git a/arch/sh/crt_arch.h b/arch/sh/crt_arch.h
index 948bcb79..f341c8fb 100644
--- a/arch/sh/crt_arch.h
+++ b/arch/sh/crt_arch.h
@@ -22,7 +22,8 @@ START ": \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"
#endif
@@ -31,11 +32,16 @@ START ": \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"
+"2: .long " START "_c@PCREL - (3b+4-.) \n"
+#ifndef SHARED
+"4: .long __fdpic_fixup@PCREL - (5b+4-.) \n"
+#endif
);
#ifndef SHARED
@@ -53,13 +59,14 @@ START ": \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"
+"2: .long " START "_c@PCREL - (3b+4-.) \n"
);
#endif