if (&rtld_DYNAMIC != NULL) {
-#ifdef __powerpc__
- /*
- * Old powerpc crt0's are going to overwrite r2 so we need to
- * restore it but only do so if the saved value isn't NULL (if
- * it is NULL, ld.elf_so doesn't have the matching change).
- */
- if ((tcb = _lwp_getprivate()) != NULL)
- __lwp_settcb(tcb);
-#endif
return;
}
Index: src/libexec/ld.elf_so/tls.c
===================================================================
RCS file: /home/chs/netbsd/cvs/src/libexec/ld.elf_so/tls.c,v
retrieving revision 1.9
diff -u -p -r1.9 tls.c
--- src/libexec/ld.elf_so/tls.c 21 Oct 2013 19:14:15 -0000 1.9
+++ src/libexec/ld.elf_so/tls.c 20 Nov 2014 21:29:18 -0000
@@ -106,13 +106,6 @@ _rtld_tls_initial_allocation(void)
tcb = _rtld_tls_allocate_locked();
#ifdef __HAVE___LWP_SETTCB
__lwp_settcb(tcb);
-#ifdef __powerpc__
- /*
- * Save the tcb pointer so that libc can retrieve it. Older
- * crt0 will obliterate r2 so there is code in libc to restore it.
- */
- _lwp_setprivate(tcb);
-#endif
#else
_lwp_setprivate(tcb);
#endif
Index: src/sys/arch/powerpc/include/types.h
===================================================================
RCS file: /home/chs/netbsd/cvs/src/sys/arch/powerpc/include/types.h,v
retrieving revision 1.49
diff -u -p -r1.49 types.h
--- src/sys/arch/powerpc/include/types.h 18 Mar 2014 18:20:41 -0000 1.49
+++ src/sys/arch/powerpc/include/types.h 21 Nov 2014 05:30:10 -0000
@@ -81,6 +81,7 @@ typedef volatile int __cpu_simple_lock_t
#ifdef _LP64
#define __HAVE_ATOMIC64_OPS
#endif
+#define __HAVE_CPU_LWP_SETPRIVATE
#define __HAVE_COMMON___TLS_GET_ADDR
#define __HAVE___LWP_GETTCB_FAST
#define __HAVE___LWP_SETTCB
Index: src/sys/arch/powerpc/powerpc/sig_machdep.c
===================================================================
RCS file: /home/chs/netbsd/cvs/src/sys/arch/powerpc/powerpc/sig_machdep.c,v
retrieving revision 1.43
diff -u -p -r1.43 sig_machdep.c
--- src/sys/arch/powerpc/powerpc/sig_machdep.c 11 Sep 2012 00:15:19 -0000 1.43
+++ src/sys/arch/powerpc/powerpc/sig_machdep.c 20 Nov 2014 21:36:37 -0000
@@ -43,6 +43,7 @@ __KERNEL_RCSID(0, "$NetBSD: sig_machdep.
#include <sys/syscallargs.h>
#include <sys/systm.h>
#include <sys/ucontext.h>
+#include <sys/cpu.h>
#ifdef PPC_HAVE_FPU
/* Save FPU context, if any. */
@@ -231,17 +231,6 @@ cpu_setmcontext(struct lwp *l, const mco
#ifdef PPC_OEA
tf->tf_mq = gr[_REG_MQ];
#endif
- /*
- * If R2 contains the TLS base, make sure to update l->l_private.
- * If not, restore R2 from l->l_private if not null. Since setcontext
- * existed before the TCB code, a static program could expect R2 to
- * the small data pointer.
- */
- if (flags & _UC_TLSBASE) {
- l->l_private = (void *) tf->tf_fixreg[_REG_R2];
- } else if (l->l_private) {
- tf->tf_fixreg[_REG_R2] = (uintptr_t)l->l_private;
- }
}