diff options
| author | Eric Andersen <andersen@codepoet.org> | 2005-05-20 19:02:51 +0000 | 
|---|---|---|
| committer | Eric Andersen <andersen@codepoet.org> | 2005-05-20 19:02:51 +0000 | 
| commit | 124af9f4b2b77b1510d88cfc8092c788d7e513c7 (patch) | |
| tree | ccce720bef4c1c604417e2082cf9997a8d6dd7ab /libpthread/nptl/sysdeps/mips | |
| parent | 8028f35dbe29c5ace3883005e08ac91d873553b2 (diff) | |
Back out nptl changes, which for now will be done in branches/uClibc-nptl
Diffstat (limited to 'libpthread/nptl/sysdeps/mips')
| -rw-r--r-- | libpthread/nptl/sysdeps/mips/Makefile | 25 | ||||
| -rw-r--r-- | libpthread/nptl/sysdeps/mips/jmpbuf-unwind.h | 30 | ||||
| -rw-r--r-- | libpthread/nptl/sysdeps/mips/nptl-sysdep.S | 2 | ||||
| -rw-r--r-- | libpthread/nptl/sysdeps/mips/pthread_spin_lock.S | 37 | ||||
| -rw-r--r-- | libpthread/nptl/sysdeps/mips/pthread_spin_trylock.S | 41 | ||||
| -rw-r--r-- | libpthread/nptl/sysdeps/mips/pthreaddef.h | 39 | ||||
| -rw-r--r-- | libpthread/nptl/sysdeps/mips/tcb-offsets.sym | 11 | ||||
| -rw-r--r-- | libpthread/nptl/sysdeps/mips/tls.h | 161 | 
8 files changed, 0 insertions, 346 deletions
| diff --git a/libpthread/nptl/sysdeps/mips/Makefile b/libpthread/nptl/sysdeps/mips/Makefile deleted file mode 100644 index d0c59a509..000000000 --- a/libpthread/nptl/sysdeps/mips/Makefile +++ /dev/null @@ -1,25 +0,0 @@ -# Copyright (C) 2005 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 -# modify it under the terms of the GNU Lesser General Public -# License as published by the Free Software Foundation; either -# version 2.1 of the License, or (at your option) any later version. -# -# The GNU C Library is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU -# Lesser General Public License for more details. -# -# You should have received a copy of the GNU Lesser General Public -# License along with the GNU C Library; if not, write to the Free -# Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA -# 02111-1307 USA. - -ifeq ($(subdir),csu) -gen-as-const-headers += tcb-offsets.sym -endif - -ifeq ($(subdir),nptl) -libpthread-sysdep_routines += nptl-sysdep -endif diff --git a/libpthread/nptl/sysdeps/mips/jmpbuf-unwind.h b/libpthread/nptl/sysdeps/mips/jmpbuf-unwind.h deleted file mode 100644 index 67cc96966..000000000 --- a/libpthread/nptl/sysdeps/mips/jmpbuf-unwind.h +++ /dev/null @@ -1,30 +0,0 @@ -/* Copyright (C) 2003, 2005 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 -   modify it under the terms of the GNU Lesser General Public -   License as published by the Free Software Foundation; either -   version 2.1 of the License, or (at your option) any later version. - -   The GNU C Library is distributed in the hope that it will be useful, -   but WITHOUT ANY WARRANTY; without even the implied warranty of -   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU -   Lesser General Public License for more details. - -   You should have received a copy of the GNU Lesser General Public -   License along with the GNU C Library; if not, write to the Free -   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA -   02111-1307 USA.  */ - -#include <setjmp.h> -#include <stdint.h> -#include <unwind.h> - -#define _JMPBUF_CFA_UNWINDS_ADJ(_jmpbuf, _context, _adj) \ -  _JMPBUF_UNWINDS_ADJ (_jmpbuf, (void *) _Unwind_GetCFA (_context), _adj) - -#define _JMPBUF_UNWINDS_ADJ(_jmpbuf, _address, _adj) \ -  ((uintptr_t) (_address) - (_adj) < (uintptr_t) (_jmpbuf)[0].__sp - (_adj)) - -/* We use the normal longjmp for unwinding.  */ -#define __libc_unwind_longjmp(buf, val) __libc_longjmp (buf, val) diff --git a/libpthread/nptl/sysdeps/mips/nptl-sysdep.S b/libpthread/nptl/sysdeps/mips/nptl-sysdep.S deleted file mode 100644 index 3f5c2a364..000000000 --- a/libpthread/nptl/sysdeps/mips/nptl-sysdep.S +++ /dev/null @@ -1,2 +0,0 @@ -/* Pull in __syscall_error.  */ -#include <sysdep.S> diff --git a/libpthread/nptl/sysdeps/mips/pthread_spin_lock.S b/libpthread/nptl/sysdeps/mips/pthread_spin_lock.S deleted file mode 100644 index d5f2a7234..000000000 --- a/libpthread/nptl/sysdeps/mips/pthread_spin_lock.S +++ /dev/null @@ -1,37 +0,0 @@ -/* Copyright (C) 2005 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 -   modify it under the terms of the GNU Lesser General Public -   License as published by the Free Software Foundation; either -   version 2.1 of the License, or (at your option) any later version. - -   The GNU C Library is distributed in the hope that it will be useful, -   but WITHOUT ANY WARRANTY; without even the implied warranty of -   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU -   Lesser General Public License for more details. - -   You should have received a copy of the GNU Lesser General Public -   License along with the GNU C Library; if not, write to the Free -   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA -   02111-1307 USA.  */ - -#include <sys/asm.h> -#include <sysdep.h> -#include <sgidefs.h> - -ENTRY (pthread_spin_lock) -	.set	push -#if _MIPS_SIM == _ABIO32 -	.set	mips2 -#endif -1:	ll	a2, 0(a0) -	li	a1, 1 -	bnez	a2, 1b -	sc	a1, 0(a0) -	beqz	a1, 1b -	MIPS_SYNC -	.set	pop -	li	v0, 0 -	ret -PSEUDO_END (pthread_spin_lock) diff --git a/libpthread/nptl/sysdeps/mips/pthread_spin_trylock.S b/libpthread/nptl/sysdeps/mips/pthread_spin_trylock.S deleted file mode 100644 index 9c6e740f0..000000000 --- a/libpthread/nptl/sysdeps/mips/pthread_spin_trylock.S +++ /dev/null @@ -1,41 +0,0 @@ -/* Copyright (C) 2005 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 -   modify it under the terms of the GNU Lesser General Public -   License as published by the Free Software Foundation; either -   version 2.1 of the License, or (at your option) any later version. - -   The GNU C Library is distributed in the hope that it will be useful, -   but WITHOUT ANY WARRANTY; without even the implied warranty of -   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU -   Lesser General Public License for more details. - -   You should have received a copy of the GNU Lesser General Public -   License along with the GNU C Library; if not, write to the Free -   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA -   02111-1307 USA.  */ - -#include <sys/asm.h> -#include <sysdep.h> -#define _ERRNO_H 1 -#include <bits/errno.h> -#include <sgidefs.h> - -ENTRY (pthread_spin_trylock) -	.set	push -#if _MIPS_SIM == _ABIO32 -	.set	mips2 -#endif -	ll	a2, 0(a0) -	li	a1, 1 -	bnez	a2, 1f -	sc	a1, 0(a0) -	beqz	a1, 1f -	MIPS_SYNC -	.set	pop -	li	v0, 0 -	ret -1:	li	v0, EBUSY -	ret -PSEUDO_END (pthread_spin_trylock) diff --git a/libpthread/nptl/sysdeps/mips/pthreaddef.h b/libpthread/nptl/sysdeps/mips/pthreaddef.h deleted file mode 100644 index e72b4bc58..000000000 --- a/libpthread/nptl/sysdeps/mips/pthreaddef.h +++ /dev/null @@ -1,39 +0,0 @@ -/* Copyright (C) 2002, 2003, 2005 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 -   modify it under the terms of the GNU Lesser General Public -   License as published by the Free Software Foundation; either -   version 2.1 of the License, or (at your option) any later version. - -   The GNU C Library is distributed in the hope that it will be useful, -   but WITHOUT ANY WARRANTY; without even the implied warranty of -   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU -   Lesser General Public License for more details. - -   You should have received a copy of the GNU Lesser General Public -   License along with the GNU C Library; if not, write to the Free -   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA -   02111-1307 USA.  */ - -/* Default stack size.  */ -#define ARCH_STACK_DEFAULT_SIZE	(2 * 1024 * 1024) - -/* Required stack pointer alignment at beginning.  */ -#define STACK_ALIGN		16 - -/* Minimal stack size after allocating thread descriptor and guard size.  */ -#define MINIMAL_REST_STACK	2048 - -/* Alignment requirement for TCB.  */ -#define TCB_ALIGNMENT		16 - - -/* Location of current stack frame.  */ -#define CURRENT_STACK_FRAME	__builtin_frame_address (0) - - -/* XXX Until we have a better place keep the definitions here.  */ - -#define __exit_thread_inline(val) \ -  INLINE_SYSCALL (exit, 1, (val)) diff --git a/libpthread/nptl/sysdeps/mips/tcb-offsets.sym b/libpthread/nptl/sysdeps/mips/tcb-offsets.sym deleted file mode 100644 index e0e71dc43..000000000 --- a/libpthread/nptl/sysdeps/mips/tcb-offsets.sym +++ /dev/null @@ -1,11 +0,0 @@ -#include <sysdep.h> -#include <tls.h> - --- - --- Abuse tls.h macros to derive offsets relative to the thread register. -#define thread_offsetof(mem)	(long)(offsetof(struct pthread, mem) - TLS_TCB_OFFSET - TLS_PRE_TCB_SIZE) - -MULTIPLE_THREADS_OFFSET		thread_offsetof (header.multiple_threads) -PID_OFFSET			thread_offsetof (pid) -TID_OFFSET			thread_offsetof (tid) diff --git a/libpthread/nptl/sysdeps/mips/tls.h b/libpthread/nptl/sysdeps/mips/tls.h deleted file mode 100644 index 1cef16101..000000000 --- a/libpthread/nptl/sysdeps/mips/tls.h +++ /dev/null @@ -1,161 +0,0 @@ -/* Definition for thread-local data handling.  NPTL/MIPS version. -   Copyright (C) 2005 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 -   modify it under the terms of the GNU Lesser General Public -   License as published by the Free Software Foundation; either -   version 2.1 of the License, or (at your option) any later version. - -   The GNU C Library is distributed in the hope that it will be useful, -   but WITHOUT ANY WARRANTY; without even the implied warranty of -   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU -   Lesser General Public License for more details. - -   You should have received a copy of the GNU Lesser General Public -   License along with the GNU C Library; if not, write to the Free -   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA -   02111-1307 USA.  */ - -#ifndef _TLS_H -#define _TLS_H	1 - -#include <dl-sysdep.h> - -#ifndef __ASSEMBLER__ -# include <stdbool.h> -# include <stddef.h> -# include <stdint.h> - -/* Type for the dtv.  */ -typedef union dtv -{ -  size_t counter; -  struct -  { -    void *val; -    bool is_static; -  } pointer; -} dtv_t; - -/* Note: rd must be $v1 to be ABI-conformant.  */ -# define READ_THREAD_POINTER() \ -    ({ void *__result;							      \ -       asm volatile (".set\tpush\n\t.set\tmips32r2\n\t"			      \ -		     "rdhwr\t%0, $29\n\t.set\tpop" : "=v" (__result));	      \ -       __result; }) - -#else /* __ASSEMBLER__ */ -# include <tcb-offsets.h> - -# define READ_THREAD_POINTER(rd) \ -	.set	push;							      \ -	.set	mips32r2;						      \ -	rdhwr	rd, $29;						      \ -	.set	pop -#endif /* __ASSEMBLER__ */ - - -/* We require TLS support in the tools.  */ -#ifndef HAVE_TLS_SUPPORT -# error "TLS support is required." -#endif - -/* Signal that TLS support is available.  */ -#define USE_TLS	1 - -#ifndef __ASSEMBLER__ - -/* Get system call information.  */ -# include <sysdep.h> - -/* The TP points to the start of the thread blocks.  */ -# define TLS_DTV_AT_TP	1 - -/* Get the thread descriptor definition.  */ -# include <nptl/descr.h> - -typedef struct -{ -  dtv_t *dtv; -  void *private; -} tcbhead_t; - -/* This is the size of the initial TCB.  Because our TCB is before the thread -   pointer, we don't need this.  */ -# define TLS_INIT_TCB_SIZE	0 - -/* Alignment requirements for the initial TCB.  */ -# define TLS_INIT_TCB_ALIGN	__alignof__ (struct pthread) - -/* This is the size of the TCB.  Because our TCB is before the thread -   pointer, we don't need this.  */ -# define TLS_TCB_SIZE		0 - -/* Alignment requirements for the TCB.  */ -# define TLS_TCB_ALIGN		__alignof__ (struct pthread) - -/* This is the size we need before TCB - actually, it includes the TCB.  */ -# define TLS_PRE_TCB_SIZE \ -  (sizeof (struct pthread)						      \ -   + ((sizeof (tcbhead_t) + TLS_TCB_ALIGN - 1) & ~(TLS_TCB_ALIGN - 1))) - -/* The thread pointer (in hardware register $29) points to the end of -   the TCB + 0x7000, as for PowerPC.  The pthread_descr structure is -   immediately in front of the TCB.  */ -# define TLS_TCB_OFFSET	0x7000 - -/* Install the dtv pointer.  The pointer passed is to the element with -   index -1 which contain the length.  */ -# define INSTALL_DTV(tcbp, dtvp) \ -  (((tcbhead_t *) (tcbp))[-1].dtv = (dtvp) + 1) - -/* Install new dtv for current thread.  */ -# define INSTALL_NEW_DTV(dtv) \ -  (THREAD_DTV() = (dtv)) - -/* Return dtv of given thread descriptor.  */ -# define GET_DTV(tcbp) \ -  (((tcbhead_t *) (tcbp))[-1].dtv) - -/* Code to initially initialize the thread pointer.  This might need -   special attention since 'errno' is not yet available and if the -   operation can cause a failure 'errno' must not be touched.  */ -# define TLS_INIT_TP(tcbp, secondcall) \ -  ({ INTERNAL_SYSCALL_DECL (err);					\ -     long result_var;							\ -     result_var = INTERNAL_SYSCALL (set_thread_area, err, 1,		\ -				    (char *) (tcbp) + TLS_TCB_OFFSET);	\ -     INTERNAL_SYSCALL_ERROR_P (result_var, err)				\ -       ? "unknown error" : NULL; }) - -/* Return the address of the dtv for the current thread.  */ -# define THREAD_DTV() \ -  (((tcbhead_t *) (READ_THREAD_POINTER () - TLS_TCB_OFFSET))[-1].dtv) - -/* Return the thread descriptor for the current thread.  */ -# define THREAD_SELF \ - ((struct pthread *) (READ_THREAD_POINTER ()			     \ -		      - TLS_TCB_OFFSET - TLS_PRE_TCB_SIZE)) - -/* Magic for libthread_db to know how to do THREAD_SELF.  */ -# define DB_THREAD_SELF \ -  CONST_THREAD_AREA (32, TLS_TCB_OFFSET + TLS_PRE_TCB_SIZE) - -/* Access to data in the thread descriptor is easy.  */ -# define THREAD_GETMEM(descr, member) \ -  descr->member -# define THREAD_GETMEM_NC(descr, member, idx) \ -  descr->member[idx] -# define THREAD_SETMEM(descr, member, value) \ -  descr->member = (value) -# define THREAD_SETMEM_NC(descr, member, idx, value) \ -  descr->member[idx] = (value) - -/* l_tls_offset == 0 is perfectly valid on MIPS, so we have to use some -   different value to mean unset l_tls_offset.  */ -# define NO_TLS_OFFSET		-1 - -#endif /* __ASSEMBLER__ */ - -#endif	/* tls.h */ | 
