Ensure __set_errno is still visible on LP32.

The use of the .hidden directive to avoid going via the PLT for
__set_errno had the side-effect of actually making __set_errno
hidden (which is odd because assembler directives don't usually
affect symbols defined in a different file --- you can't even
create a weak reference to a symbol that's defined in a different
file).

This change switches the system call stubs over to a new always-hidden
__set_errno_internal and has a visible __set_errno on LP32 just for
binary compatibility with old NDK apps.

Bug: 17423135
Change-Id: I6b6d7a05dda85f923d22e5ffd169a91e23499b7b
This commit is contained in:
Elliott Hughes
2014-09-08 15:25:01 -07:00
parent c8f6b82f87
commit 7efad83d43
1177 changed files with 1194 additions and 3506 deletions

View File

@@ -43,8 +43,6 @@ syscall_stub_header = "/* " + warning + " */\n" + \
"""
#include <private/bionic_asm.h>
.hidden __set_errno
ENTRY(%(func)s)
"""
@@ -67,7 +65,7 @@ arm_eabi_call_default = syscall_stub_header + """\
cmn r0, #(MAX_ERRNO + 1)
bxls lr
neg r0, r0
b __set_errno
b __set_errno_internal
END(%(func)s)
"""
@@ -87,7 +85,7 @@ arm_eabi_call_long = syscall_stub_header + """\
cmn r0, #(MAX_ERRNO + 1)
bxls lr
neg r0, r0
b __set_errno
b __set_errno_internal
END(%(func)s)
"""
@@ -102,7 +100,7 @@ arm64_call = syscall_stub_header + """\
cmn x0, #(MAX_ERRNO + 1)
cneg x0, x0, hi
b.hi __set_errno
b.hi __set_errno_internal
ret
END(%(func)s)
@@ -123,7 +121,7 @@ mips_call = syscall_stub_header + """\
j ra
nop
1:
la t9,__set_errno
la t9,__set_errno_internal
j t9
nop
.set reorder
@@ -150,7 +148,7 @@ mips64_call = syscall_stub_header + """\
nop
2:
.cpsetup ra, t1, 2b
LA t9,__set_errno
LA t9,__set_errno_internal
.cpreturn
j t9
move ra, t0
@@ -172,7 +170,7 @@ x86_call = """\
jb 1f
negl %%eax
pushl %%eax
call __set_errno
call __set_errno_internal
addl $4, %%esp
1:
"""
@@ -194,7 +192,7 @@ x86_64_call = """\
jb 1f
negl %%eax
movl %%eax, %%edi
call __set_errno
call __set_errno_internal
1:
ret
END(%(func)s)