2015-03-13 10:10:09 -07:00
|
|
|
#include <sysdep.h> /* For ARCH_HAS_T2. */
|
|
|
|
|
2009-02-05 14:46:41 +00:00
|
|
|
#ifdef __thumb2__
|
2015-03-13 10:10:09 -07:00
|
|
|
# define ARM_PC_OFFSET "4"
|
2009-02-05 14:46:41 +00:00
|
|
|
#else
|
2015-03-13 10:10:09 -07:00
|
|
|
# define ARM_PC_OFFSET "8"
|
2009-02-05 14:46:41 +00:00
|
|
|
#endif
|
|
|
|
|
2015-03-13 10:10:09 -07:00
|
|
|
/* Returns the address of data containing ".word SYMBOL(RELOC)". */
|
|
|
|
#if defined (ARCH_HAS_T2) && !defined (PIC)
|
|
|
|
# define GET_SPECIAL_RELOC(symbol, reloc) \
|
|
|
|
({ \
|
|
|
|
int *__##symbol##_rodata; \
|
|
|
|
asm ("movw %0, #:lower16:1f\n" \
|
|
|
|
"movt %0, #:upper16:1f\n" \
|
|
|
|
".pushsection .rodata.cst4, \"aM\", %%progbits, 4\n" \
|
|
|
|
".balign 4\n" \
|
|
|
|
"1: .word " #symbol "(" #reloc ")\n" \
|
|
|
|
".popsection" \
|
|
|
|
: "=r" (__##symbol##_rodata)); \
|
|
|
|
__##symbol##_rodata; \
|
|
|
|
})
|
|
|
|
#elif defined (ARCH_HAS_T2) && defined (PIC) && ARM_PCREL_MOVW_OK
|
|
|
|
# define GET_SPECIAL_RELOC(symbol, reloc) \
|
|
|
|
({ \
|
|
|
|
int *__##symbol##_rodata; \
|
|
|
|
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; \
|
|
|
|
})
|
2009-02-05 14:46:41 +00:00
|
|
|
#else
|
2015-03-13 10:10:09 -07:00
|
|
|
# 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; \
|
|
|
|
})
|
2009-02-05 14:46:41 +00:00
|
|
|
#endif
|
* sysdeps/arm/dl-machine.h: Include <tls.h>.
(elf_machine_type_class, elf_machine_rel, elf_machine_rela): Handle
TLS relocations.
* sysdeps/unix/sysv/linux/arm/Makefile: Build __aeabi_read_tp.
* sysdeps/unix/sysv/linux/arm/sysdep.h (INTERNAL_SYSCALL_RAW): Renamed
from INTERNAL_SYSCALL.
(INTERNAL_SYSCALL, INTERNAL_SYSCALL_ARM): New macros.
* sysdeps/arm/dl-tls.h, sysdeps/arm/elf/configure.in,
sysdeps/arm/elf/configure, sysdeps/arm/libc-tls.c,
sysdeps/arm/linuxthreads/tls.h, sysdeps/arm/tls-macros.h,
sysdeps/unix/sysv/linux/arm/aeabi_read_tp.S,
sysdeps/unix/sysv/linux/arm/libc-aeabi_read_tp.S: New files.
2005-10-05 20:15:22 +00:00
|
|
|
|
2015-03-13 10:10:09 -07:00
|
|
|
/* Returns the pointer value (SYMBOL(RELOC) + pc - PC_OFS). */
|
|
|
|
#define GET_SPECIAL_PCREL(symbol, reloc) \
|
|
|
|
({ \
|
|
|
|
int *__##symbol##_rodata = GET_SPECIAL_RELOC (symbol, reloc); \
|
|
|
|
(void *) ((int) __##symbol##_rodata + *__##symbol##_rodata); \
|
|
|
|
})
|
|
|
|
|
|
|
|
#define TLS_LE(x) \
|
|
|
|
(__builtin_thread_pointer () + *GET_SPECIAL_RELOC (x, tpoff))
|
|
|
|
|
|
|
|
#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)))
|
* sysdeps/arm/dl-machine.h: Include <tls.h>.
(elf_machine_type_class, elf_machine_rel, elf_machine_rela): Handle
TLS relocations.
* sysdeps/unix/sysv/linux/arm/Makefile: Build __aeabi_read_tp.
* sysdeps/unix/sysv/linux/arm/sysdep.h (INTERNAL_SYSCALL_RAW): Renamed
from INTERNAL_SYSCALL.
(INTERNAL_SYSCALL, INTERNAL_SYSCALL_ARM): New macros.
* sysdeps/arm/dl-tls.h, sysdeps/arm/elf/configure.in,
sysdeps/arm/elf/configure, sysdeps/arm/libc-tls.c,
sysdeps/arm/linuxthreads/tls.h, sysdeps/arm/tls-macros.h,
sysdeps/unix/sysv/linux/arm/aeabi_read_tp.S,
sysdeps/unix/sysv/linux/arm/libc-aeabi_read_tp.S: New files.
2005-10-05 20:15:22 +00:00
|
|
|
|
2015-03-13 10:10:09 -07:00
|
|
|
#define TLS_GD(x) \
|
|
|
|
((int *) __tls_get_addr (GET_SPECIAL_PCREL (x, tlsgd)))
|