There are extensions to x86-64 psABI:
https://groups.google.com/forum/#!topic/x86-64-abi/de5_KnLHxtI
and i386 psABI:
https://groups.google.com/forum/#!topic/ia32-abi/awsRSvJOJfs
to call tls_get_addr via GOT. X86 assembler and linker in binutils 2.27 implemented
call *__tls_get_addr@GOTPCREL(%rip)
in 64-bit and
call *___tls_get_addr@GOT(%reg)
in 32-bit to access global and local thread loal variables in shared library. We check if 32-bit x86 assembler and linker work with
call *___tls_get_addr@GOT(%reg)
as 32-bit and 64-bit assembler and linker are enabled togther.
In 32-bit, since any integer register except EAX, which is used to pass parameter to ___tls_get_addr, and ESP, can be used as GOT base, a new register class, TLS_GOTBASE_REGS, along with a new constraint, Yb, are added. They are used to improve register allocation for 32-bit dynamic TLS patterns.
gcc/
- configure.ac (calling ___tls_get_addr via GOT): New assembler/linker check. (HAVE_AS_IX86_TLS_GET_ADDR_GOT): New. Defined to 1 if 32-bit assembler and linker supports calling ___tls_get_addr via GOT. Otherise, defined to 0.
- config.in: Regenerated.
- configure: Likewise.
- config/i386/constraints.md (Yb): New constraint.
- config/i386/i386.h (reg_class): Add TLS_GOTBASE_REGS. (REG_CLASS_NAMES): Likewise. (REG_CLASS_CONTENTS): Likewise.
- config/i386/i386.md (*tls_global_dynamic_32_gnu): Replace the b constraint with the Yb constraint. Call ___tls_get_addr
via GOT for GNU TLS with -fno-plt if HAVE_AS_IX86_TLS_GET_ADDR_GOT is 1. (*tls_local_dynamic_base_32_gnu): Likewise. (*tls_global_dynamic_64_
gcc/testsuite/
- gcc.target/i386/noplt-gd-1.c: New test.
- gcc.target/i386/noplt-gd-2.c: Likewise.
- gcc.target/i386/noplt-gd-3.c: Likewise.
- gcc.target/i386/noplt-ld-1.c: Likewise.
- gcc.target/i386/noplt-ld-2.c: Likewise.
- gcc.target/i386/noplt-ld-3.c: Likewise.
- lib/target-supports.exp (check_effective_target_tls_get_addr_via_got): New.
c7f16cf Call tls_get_addr via GOT for GNU TLS if possible
gcc/config.in | 7 ++++
gcc/config/i386/constraints.md | 11 ++++++
gcc/config/i386/i386.h | 3 ++
gcc/config/i386/i386.md | 33 ++++++++++++-----
gcc/configure | 53 ++++++++++++++++++++++++++++
gcc/configure.ac | 30 ++++++++++++++++
gcc/testsuite/gcc.target/i386/noplt-gd-1.c | 27 ++++++++++++++
gcc/testsuite/gcc.target/i386/noplt-gd-2.c | 28 +++++++++++++++
gcc/testsuite/gcc.target/i386/noplt-gd-3.c | 12 +++++++
gcc/testsuite/gcc.target/i386/noplt-ld-1.c | 27 ++++++++++++++
gcc/testsuite/gcc.target/i386/noplt-ld-2.c | 21 +++++++++++
gcc/testsuite/gcc.target/i386/noplt-ld-3.c | 12 +++++++
gcc/testsuite/lib/target-supports.exp | 51 ++++++++++++++++++++++++++
13 files changed, 306 insertions(+), 9 deletions(-)
Upstream: gcc.gnu.org