mirror of
https://sourceware.org/git/glibc.git
synced 2025-08-01 10:06:57 +03:00
Add sparc64 TLS and NPTL support.
* elf/tls-macros.h: Add Sparc64 defines. * sysdeps/sparc/sparc64/dl-machine.h (sparc64_fixup_plt): Mark as always_inline. (elf_machine_fixup_plt): Likewise. (elf_machine_rela): Handle TLS relocations. (elf_machine_type_cleaa): Likewise. * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep.h (SYSCALL_ERROR_HANDLER_ENTRY): Use sethi/or for GOT reloc. It does not always fit in R_SPARC_GOT13 when building -fPIC. Also, add TLS handling. * sysdeps/unix/sysv/linux/configure.in (arch_minimum_kernel): Increase it to 2.4.21 for sparc64. * sysdeps/unix/sysv/linux/sparc/sparc32/clone.S: NULL terminate backtrace by zero'ing out %fp. Store away flags, func_ptr, and func_arg in global registers not local registers. * sysdeps/unix/sysv/linux/sparc/sparc64/clone.S: Handle PTID, TLS, and CTID arguments properly. Add RESET_PID handling. * sysdeps/unix/sysv/linux/sparc/sparc64/pause.c: Rework so that we do not invoke __sigprocmask(). We can always assume rt signals are present on sparc64, so just do an inline syscall. 2005-04-13 Jakub Jelinek <jakub@redhat.com> * sysdeps/sparc/sparc64/dl-machine.h: Add dl_machine_h multiple inclusion guard for the first half of the header. (elf_machine_type_class, ELF_MACHINE_JMP_SLOT, ELF_MACHINE_NO_REL, ELF_MACHINE_PLTREL_OVERLAP, elf_machine_runtime_setup, elf_machine_relplt, DL_STACK_END, RTLD_START): Move into the #ifndef dl_machine_h guarded part of the header.
This commit is contained in:
@ -441,6 +441,74 @@ register void *__gp __asm__("$29");
|
||||
"o5", "o7", "cc"); \
|
||||
__o0; })
|
||||
|
||||
#elif defined __sparc__ && defined __arch64__
|
||||
|
||||
# define TLS_LE(x) \
|
||||
({ int *__l; \
|
||||
asm ("sethi %%tle_hix22(" #x "), %0" : "=r" (__l)); \
|
||||
asm ("xor %1, %%tle_lox10(" #x "), %0" : "=r" (__l) : "r" (__l)); \
|
||||
asm ("add %%g7, %1, %0" : "=r" (__l) : "r" (__l)); \
|
||||
__l; })
|
||||
|
||||
# ifdef __PIC__
|
||||
# define TLS_LOAD_PIC \
|
||||
({ long pc, got; \
|
||||
asm ("sethi %%hi(_GLOBAL_OFFSET_TABLE_-4), %1\n\t" \
|
||||
"rd %%pc, %0\n\t" \
|
||||
"add %1, %%lo(_GLOBAL_OFFSET_TABLE_+4), %1\n\t" \
|
||||
"add %1, %0, %1\n\t" \
|
||||
: "=r" (pc), "=r" (got)); \
|
||||
got; })
|
||||
# else
|
||||
# define TLS_LOAD_PIC \
|
||||
({ long got; \
|
||||
asm (".hidden _GLOBAL_OFFSET_TABLE_\n\t" \
|
||||
"sethi %%hi(_GLOBAL_OFFSET_TABLE_), %0\n\t" \
|
||||
"or %0, %%lo(_GLOBAL_OFFSET_TABLE_), %0" \
|
||||
: "=r" (got)); \
|
||||
got; })
|
||||
# endif
|
||||
|
||||
# define TLS_IE(x) \
|
||||
({ int *__l; \
|
||||
asm ("sethi %%tie_hi22(" #x "), %0" : "=r" (__l)); \
|
||||
asm ("add %1, %%tie_lo10(" #x "), %0" : "=r" (__l) : "r" (__l)); \
|
||||
asm ("ldx [%1 + %2], %0, %%tie_ldx(" #x ")" \
|
||||
: "=r" (__l) : "r" (TLS_LOAD_PIC), "r" (__l)); \
|
||||
asm ("add %%g7, %1, %0, %%tie_add(" #x ")" : "=r" (__l) : "r" (__l)); \
|
||||
__l; })
|
||||
|
||||
# define TLS_LD(x) \
|
||||
({ int *__l; register void *__o0 asm ("%o0"); \
|
||||
long __o; \
|
||||
asm ("sethi %%tldm_hi22(" #x "), %0" : "=r" (__l)); \
|
||||
asm ("add %1, %%tldm_lo10(" #x "), %0" : "=r" (__l) : "r" (__l)); \
|
||||
asm ("add %1, %2, %0, %%tldm_add(" #x ")" \
|
||||
: "=r" (__o0) : "r" (TLS_LOAD_PIC), "r" (__l)); \
|
||||
asm ("call __tls_get_addr, %%tgd_call(" #x ")\n\t" \
|
||||
" nop" \
|
||||
: "=r" (__o0) : "0" (__o0) \
|
||||
: "g1", "g2", "g3", "g4", "g5", "g6", "o1", "o2", "o3", "o4", \
|
||||
"o5", "o7", "cc"); \
|
||||
asm ("sethi %%tldo_hix22(" #x "), %0" : "=r" (__o)); \
|
||||
asm ("xor %1, %%tldo_lox10(" #x "), %0" : "=r" (__o) : "r" (__o)); \
|
||||
asm ("add %1, %2, %0, %%tldo_add(" #x ")" : "=r" (__l) \
|
||||
: "r" (__o0), "r" (__o)); \
|
||||
__l; })
|
||||
|
||||
# define TLS_GD(x) \
|
||||
({ int *__l; register void *__o0 asm ("%o0"); \
|
||||
asm ("sethi %%tgd_hi22(" #x "), %0" : "=r" (__l)); \
|
||||
asm ("add %1, %%tgd_lo10(" #x "), %0" : "=r" (__l) : "r" (__l)); \
|
||||
asm ("add %1, %2, %0, %%tgd_add(" #x ")" \
|
||||
: "=r" (__o0) : "r" (TLS_LOAD_PIC), "r" (__l)); \
|
||||
asm ("call __tls_get_addr, %%tgd_call(" #x ")\n\t" \
|
||||
" nop" \
|
||||
: "=r" (__o0) : "0" (__o0) \
|
||||
: "g1", "g2", "g3", "g4", "g5", "g6", "o1", "o2", "o3", "o4", \
|
||||
"o5", "o7", "cc"); \
|
||||
__o0; })
|
||||
|
||||
#elif defined __s390x__
|
||||
|
||||
# define TLS_LE(x) \
|
||||
|
Reference in New Issue
Block a user