diff options
author | Roland McGrath <roland@gnu.org> | 2002-09-25 01:58:37 +0000 |
---|---|---|
committer | Roland McGrath <roland@gnu.org> | 2002-09-25 01:58:37 +0000 |
commit | 160bb4094514b41e70a4701235fb622c0061442b (patch) | |
tree | 3c176309b281310c577d02a235035534bffbb56f /elf/tls-macros.h | |
parent | 1e78de0594ad3963cb789ff82f9e50ec7c48fd9d (diff) | |
download | glibc-160bb4094514b41e70a4701235fb622c0061442b.tar.gz |
* csu/Versions: Use %include <tls.h> to get USE_TLS defined.
(libc: GLIBC_2.0) [USE_TLS && HAVE___THREAD]: Remove _errno, errno.
(libc: GLIBC_2.3) [USE_TLS && HAVE___THREAD]: Put errno here instead.
* resolv/Versions: Use %include <tls.h> to get USE_TLS defined.
(libc: GLIBC_2.0) [USE_TLS && HAVE___THREAD]: Remove _h_errno, h_errno,
and _res.
(libc: GLIBC_2.3) [USE_TLS && HAVE___THREAD]: Put h_errno, _res here.
* elf/tls-macros.h [__x86_64__] (TLS_LE, TLS_IE, TLS_LD, TLS_GD):
New macros for x86-64.
* sysdeps/unix/sysv/linux/alpha/bits/time.h: File removed.
It was indentical to the linux/bits/time.h file.
* nscd/nscd_gethst_r.c (nscd_gethst_r): Add a cast to silence warning.
* resolv/gethnamaddr.c (gethostbyaddr): Use socklen_t for SIZE.
Diffstat (limited to 'elf/tls-macros.h')
-rw-r--r-- | elf/tls-macros.h | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/elf/tls-macros.h b/elf/tls-macros.h index 877581198c..2e3635d26f 100644 --- a/elf/tls-macros.h +++ b/elf/tls-macros.h @@ -95,7 +95,42 @@ __l; }) # endif +#elif defined __x86_64__ + +# define TLS_LE(x) \ + ({ int *__l; \ + asm ("movq %%fs:0,%0\n\t" \ + "leaq " #x "@tpoff(%0), %0" \ + : "=r" (__l)); \ + __l; }) + +# define TLS_IE(x) \ + ({ int *__l; \ + asm ("movq %%fs:0,%0\n\t" \ + "addq " #x "@gottpoff(%%rip),%0" \ + : "=r" (__l)); \ + __l; }) + +# define TLS_LD(x) \ + ({ int *__l, __c, __d; \ + asm ("leaq " #x "@tlsld(%%rip),%%rdi\n\t" \ + "callq __tls_get_addr@plt\n\t" \ + "leaq " #x "@dtpoff(%%rax), %%rax" \ + : "=a" (__l), "=&c" (__c), "=&d" (__d) \ + : : "rdi", "rsi", "r8", "r9", "r10", "r11"); \ + __l; }) + +# define TLS_GD(x) \ + ({ int *__l, __c, __d; \ + asm (".long 0x66666666\n\t" \ + "leaq " #x "@tlsgd(%%rip),%%rdi\n\t" \ + "callq __tls_get_addr@plt" \ + : "=a" (__l), "=&c" (__c), "=&d" (__d) \ + : : "rdi", "rsi", "r8", "r9", "r10", "r11"); \ + __l; }) + #elif defined __sh__ + # define TLS_LE(x) \ ({ int *__l; void *__tp; \ asm ("stc gbr,%1\n\t" \ |