diff options
| author | Austin Foxley <austinf@cetoncorp.com> | 2010-02-16 12:27:18 -0800 | 
|---|---|---|
| committer | Austin Foxley <austinf@cetoncorp.com> | 2010-02-16 12:27:18 -0800 | 
| commit | a032a6587011cbdac8c2f7e11f15dc4e592bbb55 (patch) | |
| tree | b8d8dfc6abf0168e098223c2134a3e4bd7640942 /libpthread/nptl/sysdeps/powerpc | |
| parent | 70f1d42b13a741f603472f405299e5d2938aa728 (diff) | |
mass sync with glibc nptl
Signed-off-by: Austin Foxley <austinf@cetoncorp.com>
Diffstat (limited to 'libpthread/nptl/sysdeps/powerpc')
| -rw-r--r-- | libpthread/nptl/sysdeps/powerpc/tcb-offsets.sym | 4 | ||||
| -rw-r--r-- | libpthread/nptl/sysdeps/powerpc/tls.h | 42 | 
2 files changed, 43 insertions, 3 deletions
| diff --git a/libpthread/nptl/sysdeps/powerpc/tcb-offsets.sym b/libpthread/nptl/sysdeps/powerpc/tcb-offsets.sym index 3962edbd5..8ac133dfd 100644 --- a/libpthread/nptl/sysdeps/powerpc/tcb-offsets.sym +++ b/libpthread/nptl/sysdeps/powerpc/tcb-offsets.sym @@ -14,3 +14,7 @@ MULTIPLE_THREADS_OFFSET		thread_offsetof (header.multiple_threads)  #endif  PID				thread_offsetof (pid)  TID				thread_offsetof (tid) +POINTER_GUARD			(offsetof (tcbhead_t, pointer_guard) - TLS_TCB_OFFSET - sizeof (tcbhead_t)) +#ifndef __ASSUME_PRIVATE_FUTEX +PRIVATE_FUTEX_OFFSET		thread_offsetof (header.private_futex) +#endif diff --git a/libpthread/nptl/sysdeps/powerpc/tls.h b/libpthread/nptl/sysdeps/powerpc/tls.h index 1157116a3..ce5559eef 100644 --- a/libpthread/nptl/sysdeps/powerpc/tls.h +++ b/libpthread/nptl/sysdeps/powerpc/tls.h @@ -1,5 +1,5 @@  /* Definition for thread-local data handling.  NPTL/PowerPC version. -   Copyright (C) 2003, 2005 Free Software Foundation, Inc. +   Copyright (C) 2003, 2005, 2006, 2007 Free Software Foundation, Inc.     This file is part of the GNU C Library.     The GNU C Library is free software; you can redistribute it and/or @@ -47,7 +47,7 @@ typedef union dtv  #endif  /* Signal that TLS support is available.  */ -# define USE_TLS	1 +# define USE_TLS       1  #ifndef __ASSEMBLER__ @@ -64,9 +64,11 @@ typedef union dtv  # include <nptl/descr.h>  /* The stack_guard is accessed directly by GCC -fstack-protector code, -   so it is a part of public ABI.  The dtv field is private.  */ +   so it is a part of public ABI.  The dtv and pointer_guard fields +   are private.  */  typedef struct  { +  uintptr_t pointer_guard;    uintptr_t stack_guard;    dtv_t *dtv;  } tcbhead_t; @@ -164,10 +166,44 @@ register void *__thread_register __asm__ ("r13");       = ((tcbhead_t *) ((char *) __thread_register			      \  		       - TLS_TCB_OFFSET))[-1].stack_guard) +/* Set the stack guard field in TCB head.  */ +# define THREAD_GET_POINTER_GUARD() \ +    (((tcbhead_t *) ((char *) __thread_register				      \ +		     - TLS_TCB_OFFSET))[-1].pointer_guard) +# define THREAD_SET_POINTER_GUARD(value) \ +    (THREAD_GET_POINTER_GUARD () = (value)) +# define THREAD_COPY_POINTER_GUARD(descr) \ +    (((tcbhead_t *) ((char *) (descr)					      \ +		     + TLS_PRE_TCB_SIZE))[-1].pointer_guard		      \ +     = THREAD_GET_POINTER_GUARD()) +  /* l_tls_offset == 0 is perfectly valid on PPC, so we have to use some     different value to mean unset l_tls_offset.  */  # define NO_TLS_OFFSET		-1 +/* Get and set the global scope generation counter in struct pthread.  */ +#define THREAD_GSCOPE_FLAG_UNUSED 0 +#define THREAD_GSCOPE_FLAG_USED   1 +#define THREAD_GSCOPE_FLAG_WAIT   2 +#define THREAD_GSCOPE_RESET_FLAG() \ +  do									     \ +    { int __res								     \ +	= atomic_exchange_rel (&THREAD_SELF->header.gscope_flag,	     \ +			       THREAD_GSCOPE_FLAG_UNUSED);		     \ +      if (__res == THREAD_GSCOPE_FLAG_WAIT)				     \ +	lll_futex_wake (&THREAD_SELF->header.gscope_flag, 1, LLL_PRIVATE);   \ +    }									     \ +  while (0) +#define THREAD_GSCOPE_SET_FLAG() \ +  do									     \ +    {									     \ +      THREAD_SELF->header.gscope_flag = THREAD_GSCOPE_FLAG_USED;	     \ +      atomic_write_barrier ();						     \ +    }									     \ +  while (0) +#define THREAD_GSCOPE_WAIT() \ +  GL(dl_wait_lookup_done) () +  #endif /* __ASSEMBLER__ */  #endif	/* tls.h */ | 
