mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-25 22:40:05 +00:00
ARM: Rewrite sysdeps/arm/tls-macros.h
This commit is contained in:
parent
cf9313e7d1
commit
cdaf79d0af
@ -1,3 +1,11 @@
|
|||||||
|
2015-03-13 Roland McGrath <roland@hack.frob.com>
|
||||||
|
|
||||||
|
* sysdeps/arm/tls-macros.h: Include <sysdep.h>.
|
||||||
|
(GET_SPECIAL_RELOC, GET_SPECIAL_PCREL): New macros to encapsulate
|
||||||
|
all the necessary asm magic in one place.
|
||||||
|
(TLS_LE, TLS_IE, TLS_LD, TLS_GD): Rewritten as C expressions
|
||||||
|
using those.
|
||||||
|
|
||||||
2015-03-13 Carlos O'Donell <carlos@redhat.com>
|
2015-03-13 Carlos O'Donell <carlos@redhat.com>
|
||||||
|
|
||||||
[BZ #14906]
|
[BZ #14906]
|
||||||
|
@ -1,78 +1,72 @@
|
|||||||
#ifdef __thumb2__
|
#include <sysdep.h> /* For ARCH_HAS_T2. */
|
||||||
#define ARM_PC_OFFSET "4"
|
|
||||||
#else
|
|
||||||
#define ARM_PC_OFFSET "8"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define TLS_LE(x) \
|
|
||||||
({ int *__result; \
|
|
||||||
void *tp = __builtin_thread_pointer (); \
|
|
||||||
asm ("ldr %0, 1f; " \
|
|
||||||
"add %0, %1, %0; " \
|
|
||||||
"b 2f; " \
|
|
||||||
".align 2; " \
|
|
||||||
"1: .word " #x "(tpoff); " \
|
|
||||||
"2: " \
|
|
||||||
: "=&r" (__result) : "r" (tp)); \
|
|
||||||
__result; })
|
|
||||||
|
|
||||||
#ifdef __thumb2__
|
#ifdef __thumb2__
|
||||||
#define TLS_IE(x) \
|
# define ARM_PC_OFFSET "4"
|
||||||
({ int *__result; \
|
|
||||||
void *tp = __builtin_thread_pointer (); \
|
|
||||||
asm ("ldr %0, 1f; " \
|
|
||||||
"3: add %0, pc, %0;" \
|
|
||||||
"ldr %0, [%0];" \
|
|
||||||
"add %0, %1, %0; " \
|
|
||||||
"b 2f; " \
|
|
||||||
".align 2; " \
|
|
||||||
"1: .word " #x "(gottpoff) + (. - 3b - 4); " \
|
|
||||||
"2: " \
|
|
||||||
: "=&r" (__result) : "r" (tp)); \
|
|
||||||
__result; })
|
|
||||||
#else
|
#else
|
||||||
#define TLS_IE(x) \
|
# define ARM_PC_OFFSET "8"
|
||||||
({ int *__result; \
|
|
||||||
void *tp = __builtin_thread_pointer (); \
|
|
||||||
asm ("ldr %0, 1f; " \
|
|
||||||
"3: ldr %0, [pc, %0];" \
|
|
||||||
"add %0, %1, %0; " \
|
|
||||||
"b 2f; " \
|
|
||||||
".align 2; " \
|
|
||||||
"1: .word " #x "(gottpoff) + (. - 3b - 8); " \
|
|
||||||
"2: " \
|
|
||||||
: "=&r" (__result) : "r" (tp)); \
|
|
||||||
__result; })
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define TLS_LD(x) \
|
/* Returns the address of data containing ".word SYMBOL(RELOC)". */
|
||||||
({ char *__result; \
|
#if defined (ARCH_HAS_T2) && !defined (PIC)
|
||||||
int __offset; \
|
# define GET_SPECIAL_RELOC(symbol, reloc) \
|
||||||
extern void *__tls_get_addr (void *); \
|
({ \
|
||||||
asm ("ldr %0, 2f; " \
|
int *__##symbol##_rodata; \
|
||||||
"1: add %0, pc, %0; " \
|
asm ("movw %0, #:lower16:1f\n" \
|
||||||
"b 3f; " \
|
"movt %0, #:upper16:1f\n" \
|
||||||
".align 2; " \
|
".pushsection .rodata.cst4, \"aM\", %%progbits, 4\n" \
|
||||||
"2: .word " #x "(tlsldm) + (. - 1b - "ARM_PC_OFFSET"); " \
|
".balign 4\n" \
|
||||||
"3: " \
|
"1: .word " #symbol "(" #reloc ")\n" \
|
||||||
: "=r" (__result)); \
|
".popsection" \
|
||||||
__result = (char *)__tls_get_addr (__result); \
|
: "=r" (__##symbol##_rodata)); \
|
||||||
asm ("ldr %0, 1f; " \
|
__##symbol##_rodata; \
|
||||||
"b 2f; " \
|
})
|
||||||
".align 2; " \
|
#elif defined (ARCH_HAS_T2) && defined (PIC) && ARM_PCREL_MOVW_OK
|
||||||
"1: .word " #x "(tlsldo); " \
|
# define GET_SPECIAL_RELOC(symbol, reloc) \
|
||||||
"2: " \
|
({ \
|
||||||
: "=r" (__offset)); \
|
int *__##symbol##_rodata; \
|
||||||
(int *) (__result + __offset); })
|
asm ("movw %0, #:lower16:1f - 2f - " ARM_PC_OFFSET "\n" \
|
||||||
|
"movt %0, #:upper16:1f - 2f - " ARM_PC_OFFSET "\n" \
|
||||||
|
".pushsection .rodata.cst4, \"aM\", %%progbits, 4\n" \
|
||||||
|
".balign 4\n" \
|
||||||
|
"1: .word " #symbol "(" #reloc ")\n" \
|
||||||
|
".popsection\n" \
|
||||||
|
"2: add %0, %0, pc" \
|
||||||
|
: "=r" (__##symbol##_rodata)); \
|
||||||
|
__##symbol##_rodata; \
|
||||||
|
})
|
||||||
|
#else
|
||||||
|
# define GET_SPECIAL_RELOC(symbol, reloc) \
|
||||||
|
({ \
|
||||||
|
int *__##symbol##_rodata; \
|
||||||
|
asm ("adr %0, 1f\n" \
|
||||||
|
"b 2f\n" \
|
||||||
|
".balign 4\n" \
|
||||||
|
"1: .word " #symbol "(" #reloc ")\n" \
|
||||||
|
"2:" \
|
||||||
|
: "=r" (__##symbol##_rodata)); \
|
||||||
|
__##symbol##_rodata; \
|
||||||
|
})
|
||||||
|
#endif
|
||||||
|
|
||||||
#define TLS_GD(x) \
|
/* Returns the pointer value (SYMBOL(RELOC) + pc - PC_OFS). */
|
||||||
({ int *__result; \
|
#define GET_SPECIAL_PCREL(symbol, reloc) \
|
||||||
extern void *__tls_get_addr (void *); \
|
({ \
|
||||||
asm ("ldr %0, 2f; " \
|
int *__##symbol##_rodata = GET_SPECIAL_RELOC (symbol, reloc); \
|
||||||
"1: add %0, pc, %0; " \
|
(void *) ((int) __##symbol##_rodata + *__##symbol##_rodata); \
|
||||||
"b 3f; " \
|
})
|
||||||
".align 2; " \
|
|
||||||
"2: .word " #x "(tlsgd) + (. - 1b - "ARM_PC_OFFSET"); " \
|
#define TLS_LE(x) \
|
||||||
"3: " \
|
(__builtin_thread_pointer () + *GET_SPECIAL_RELOC (x, tpoff))
|
||||||
: "=r" (__result)); \
|
|
||||||
(int *)__tls_get_addr (__result); })
|
#define TLS_IE(x) \
|
||||||
|
((int *) (__builtin_thread_pointer () \
|
||||||
|
+ *(int *) GET_SPECIAL_PCREL (x, gottpoff)))
|
||||||
|
|
||||||
|
extern void *__tls_get_addr (void *);
|
||||||
|
|
||||||
|
#define TLS_LD(x) \
|
||||||
|
((int *) (__tls_get_addr (GET_SPECIAL_PCREL (x, tlsldm)) \
|
||||||
|
+ *GET_SPECIAL_RELOC (x, tlsldo)))
|
||||||
|
|
||||||
|
#define TLS_GD(x) \
|
||||||
|
((int *) __tls_get_addr (GET_SPECIAL_PCREL (x, tlsgd)))
|
||||||
|
Loading…
Reference in New Issue
Block a user