mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-18 06:30:05 +00:00
* init.c (__pthread_initialize_minimal_internal): Check whether
private futexes are available. * allocatestack.c (allocate_stack): Copy private_futex field from current thread into the new stack. * sysdeps/unix/sysv/linux/x86_64/libc-lowlevellock.S: Use private futexes if they are available. * sysdeps/unix/sysv/linux/i386/i486/libc-lowlevellock.S: Likewise * sysdeps/unix/sysv/linux/x86_64/lowlevellock.S: Adjust so that change in libc-lowlevellock.S allow using private futexes. * sysdeps/unix/sysv/linux/i386/i486/lowlevellock.S: Likewise. * sysdeps/unix/sysv/linux/x86_64/lowlevellock.h: Define FUTEX_PRIVATE_FLAG. * sysdeps/unix/sysv/linux/i386/lowlevellock.h: Likewise. * sysdeps/unix/sysv/linux/x86_64/pthread_once.S: Use private futexes if they are available. * sysdeps/unix/sysv/linux/i386/pthread_once.S: Likewise. * sysdeps/x86_64/tcb-offsets.sym: Add PRIVATE_FUTEX. * sysdeps/i386/tcb-offsets.sym: Likewise. * sysdeps/x86_64/tls.h (tcbhead_t): Add private_futex field. * sysdeps/i386/tls.h (tcbhead_t): Likewise.
This commit is contained in:
parent
6d59823c29
commit
5a8075b116
@ -1,3 +1,26 @@
|
|||||||
|
2007-05-23 Ulrich Drepper <drepper@redhat.com>
|
||||||
|
|
||||||
|
* init.c (__pthread_initialize_minimal_internal): Check whether
|
||||||
|
private futexes are available.
|
||||||
|
* allocatestack.c (allocate_stack): Copy private_futex field from
|
||||||
|
current thread into the new stack.
|
||||||
|
* sysdeps/unix/sysv/linux/x86_64/libc-lowlevellock.S: Use private
|
||||||
|
futexes if they are available.
|
||||||
|
* sysdeps/unix/sysv/linux/i386/i486/libc-lowlevellock.S: Likewise
|
||||||
|
* sysdeps/unix/sysv/linux/x86_64/lowlevellock.S: Adjust so that change
|
||||||
|
in libc-lowlevellock.S allow using private futexes.
|
||||||
|
* sysdeps/unix/sysv/linux/i386/i486/lowlevellock.S: Likewise.
|
||||||
|
* sysdeps/unix/sysv/linux/x86_64/lowlevellock.h: Define
|
||||||
|
FUTEX_PRIVATE_FLAG.
|
||||||
|
* sysdeps/unix/sysv/linux/i386/lowlevellock.h: Likewise.
|
||||||
|
* sysdeps/unix/sysv/linux/x86_64/pthread_once.S: Use private futexes
|
||||||
|
if they are available.
|
||||||
|
* sysdeps/unix/sysv/linux/i386/pthread_once.S: Likewise.
|
||||||
|
* sysdeps/x86_64/tcb-offsets.sym: Add PRIVATE_FUTEX.
|
||||||
|
* sysdeps/i386/tcb-offsets.sym: Likewise.
|
||||||
|
* sysdeps/x86_64/tls.h (tcbhead_t): Add private_futex field.
|
||||||
|
* sysdeps/i386/tls.h (tcbhead_t): Likewise.
|
||||||
|
|
||||||
2007-05-21 Ulrich Drepper <drepper@redhat.com>
|
2007-05-21 Ulrich Drepper <drepper@redhat.com>
|
||||||
|
|
||||||
* sysdeps/pthread/pthread-functions.h (struct pthread_functions):
|
* sysdeps/pthread/pthread-functions.h (struct pthread_functions):
|
||||||
|
@ -376,6 +376,12 @@ allocate_stack (const struct pthread_attr *attr, struct pthread **pdp,
|
|||||||
__pthread_multiple_threads = *__libc_multiple_threads_ptr = 1;
|
__pthread_multiple_threads = *__libc_multiple_threads_ptr = 1;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef __ASSUME_PRIVATE_FUTEX
|
||||||
|
/* The thread must know when private futexes are supported. */
|
||||||
|
pd->header.private_futex = THREAD_GETMEM (THREAD_SELF,
|
||||||
|
header.private_futex);
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef NEED_DL_SYSINFO
|
#ifdef NEED_DL_SYSINFO
|
||||||
/* Copy the sysinfo value from the parent. */
|
/* Copy the sysinfo value from the parent. */
|
||||||
THREAD_SYSINFO(pd) = THREAD_SELF_SYSINFO;
|
THREAD_SYSINFO(pd) = THREAD_SELF_SYSINFO;
|
||||||
@ -510,6 +516,12 @@ allocate_stack (const struct pthread_attr *attr, struct pthread **pdp,
|
|||||||
__pthread_multiple_threads = *__libc_multiple_threads_ptr = 1;
|
__pthread_multiple_threads = *__libc_multiple_threads_ptr = 1;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef __ASSUME_PRIVATE_FUTEX
|
||||||
|
/* The thread must know when private futexes are supported. */
|
||||||
|
pd->header.private_futex = THREAD_GETMEM (THREAD_SELF,
|
||||||
|
header.private_futex);
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef NEED_DL_SYSINFO
|
#ifdef NEED_DL_SYSINFO
|
||||||
/* Copy the sysinfo value from the parent. */
|
/* Copy the sysinfo value from the parent. */
|
||||||
THREAD_SYSINFO(pd) = THREAD_SELF_SYSINFO;
|
THREAD_SYSINFO(pd) = THREAD_SELF_SYSINFO;
|
||||||
|
12
nptl/init.c
12
nptl/init.c
@ -276,6 +276,18 @@ __pthread_initialize_minimal_internal (void)
|
|||||||
#endif
|
#endif
|
||||||
set_robust_list_not_avail ();
|
set_robust_list_not_avail ();
|
||||||
|
|
||||||
|
#ifndef __ASSUME_PRIVATE_FUTEX
|
||||||
|
/* Private futexes are always used (at least internally) so that
|
||||||
|
doing the test once this early is beneficial. */
|
||||||
|
{
|
||||||
|
int word;
|
||||||
|
res = INTERNAL_SYSCALL (futex, err, 3, &word,
|
||||||
|
FUTEX_WAKE | FUTEX_PRIVATE_FLAG, 1);
|
||||||
|
if (!INTERNAL_SYSCALL_ERROR_P (res, err))
|
||||||
|
THREAD_SETMEM (pd, header.private_futex, FUTEX_PRIVATE_FLAG);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Set initial thread's stack block from 0 up to __libc_stack_end.
|
/* Set initial thread's stack block from 0 up to __libc_stack_end.
|
||||||
It will be bigger than it actually is, but for unwind.c/pt-longjmp.c
|
It will be bigger than it actually is, but for unwind.c/pt-longjmp.c
|
||||||
purposes this is good enough. */
|
purposes this is good enough. */
|
||||||
|
@ -12,3 +12,6 @@ CLEANUP offsetof (struct pthread, cleanup)
|
|||||||
CLEANUP_PREV offsetof (struct _pthread_cleanup_buffer, __prev)
|
CLEANUP_PREV offsetof (struct _pthread_cleanup_buffer, __prev)
|
||||||
MUTEX_FUTEX offsetof (pthread_mutex_t, __data.__lock)
|
MUTEX_FUTEX offsetof (pthread_mutex_t, __data.__lock)
|
||||||
POINTER_GUARD offsetof (tcbhead_t, pointer_guard)
|
POINTER_GUARD offsetof (tcbhead_t, pointer_guard)
|
||||||
|
#ifndef __ASSUME_PRIVATE_FUTEX
|
||||||
|
PRIVATE_FUTEX offsetof (tcbhead_t, private_futex)
|
||||||
|
#endif
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
# include <stdlib.h>
|
# include <stdlib.h>
|
||||||
# include <list.h>
|
# include <list.h>
|
||||||
# include <sysdep.h>
|
# include <sysdep.h>
|
||||||
|
# include <kernel-features.h>
|
||||||
|
|
||||||
|
|
||||||
/* Type for the dtv. */
|
/* Type for the dtv. */
|
||||||
@ -53,6 +54,9 @@ typedef struct
|
|||||||
uintptr_t stack_guard;
|
uintptr_t stack_guard;
|
||||||
uintptr_t pointer_guard;
|
uintptr_t pointer_guard;
|
||||||
int gscope_flag;
|
int gscope_flag;
|
||||||
|
#ifndef __ASSUME_PRIVATE_FUTEX
|
||||||
|
int private_futex;
|
||||||
|
#endif
|
||||||
} tcbhead_t;
|
} tcbhead_t;
|
||||||
|
|
||||||
# define TLS_MULTIPLE_THREADS_IN_TCB 1
|
# define TLS_MULTIPLE_THREADS_IN_TCB 1
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 2002, 2003 Free Software Foundation, Inc.
|
/* Copyright (C) 2002, 2003, 2007 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
|
Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
|
||||||
|
|
||||||
@ -17,6 +17,8 @@
|
|||||||
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
||||||
02111-1307 USA. */
|
02111-1307 USA. */
|
||||||
|
|
||||||
|
#include <kernel-features.h>
|
||||||
|
|
||||||
/* In libc.so we do not unconditionally use the lock prefix. Only if
|
/* In libc.so we do not unconditionally use the lock prefix. Only if
|
||||||
the application is using threads. */
|
the application is using threads. */
|
||||||
#ifndef UP
|
#ifndef UP
|
||||||
@ -27,4 +29,17 @@
|
|||||||
0:
|
0:
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* All locks in libc are private. Use the kernel feature if possible. */
|
||||||
|
#define FUTEX_PRIVATE_FLAG 128
|
||||||
|
#ifdef __ASSUME_PRIVATE_FUTEX
|
||||||
|
# define FUTEX_WAIT (0 | FUTEX_PRIVATE_FLAG)
|
||||||
|
# define FUTEX_WAKE (1 | FUTEX_PRIVATE_FLAG)
|
||||||
|
#else
|
||||||
|
# define LOAD_FUTEX_WAIT(reg) \
|
||||||
|
movl %gs:PRIVATE_FUTEX, reg
|
||||||
|
# define LOAD_FUTEX_WAKE(reg) \
|
||||||
|
movl %gs:PRIVATE_FUTEX, reg ; \
|
||||||
|
orl $FUTEX_WAKE, reg
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "lowlevellock.S"
|
#include "lowlevellock.S"
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 2002, 2003, 2004, 2006 Free Software Foundation, Inc.
|
/* Copyright (C) 2002, 2003, 2004, 2006, 2007 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
|
Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
|
||||||
|
|
||||||
@ -32,8 +32,22 @@
|
|||||||
|
|
||||||
#define SYS_gettimeofday __NR_gettimeofday
|
#define SYS_gettimeofday __NR_gettimeofday
|
||||||
#define SYS_futex 240
|
#define SYS_futex 240
|
||||||
#define FUTEX_WAIT 0
|
#ifndef FUTEX_WAIT
|
||||||
#define FUTEX_WAKE 1
|
# define FUTEX_WAIT 0
|
||||||
|
# define FUTEX_WAKE 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef LOAD_FUTEX_WAIT
|
||||||
|
# if FUTEX_WAIT == 0
|
||||||
|
# define LOAD_FUTEX_WAIT(reg) \
|
||||||
|
xorl reg, reg
|
||||||
|
# else
|
||||||
|
# define LOAD_FUTEX_WAIT(reg) \
|
||||||
|
movl $FUTEX_WAIT, reg
|
||||||
|
# endif
|
||||||
|
# define LOAD_FUTEX_WAKE(reg) \
|
||||||
|
movl $FUTEX_WAKE, reg
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
.globl __lll_mutex_lock_wait
|
.globl __lll_mutex_lock_wait
|
||||||
@ -55,7 +69,7 @@ __lll_mutex_lock_wait:
|
|||||||
movl $2, %edx
|
movl $2, %edx
|
||||||
movl %ecx, %ebx
|
movl %ecx, %ebx
|
||||||
xorl %esi, %esi /* No timeout. */
|
xorl %esi, %esi /* No timeout. */
|
||||||
xorl %ecx, %ecx /* movl $FUTEX_WAIT, %ecx */
|
LOAD_FUTEX_WAIT (%ecx)
|
||||||
|
|
||||||
cmpl %edx, %eax /* NB: %edx == 2 */
|
cmpl %edx, %eax /* NB: %edx == 2 */
|
||||||
jne 2f
|
jne 2f
|
||||||
@ -151,7 +165,7 @@ __lll_mutex_timedlock_wait:
|
|||||||
|
|
||||||
/* Futex call. */
|
/* Futex call. */
|
||||||
movl %esp, %esi
|
movl %esp, %esi
|
||||||
xorl %ecx, %ecx /* movl $FUTEX_WAIT, %ecx */
|
LOAD_FUTEX_WAIT (%ecx)
|
||||||
movl $SYS_futex, %eax
|
movl $SYS_futex, %eax
|
||||||
ENTER_KERNEL
|
ENTER_KERNEL
|
||||||
movl %eax, %ecx
|
movl %eax, %ecx
|
||||||
@ -252,7 +266,7 @@ __lll_mutex_unlock_wake:
|
|||||||
|
|
||||||
movl %eax, %ebx
|
movl %eax, %ebx
|
||||||
movl $0, (%eax)
|
movl $0, (%eax)
|
||||||
movl $FUTEX_WAKE, %ecx
|
LOAD_FUTEX_WAKE (%ecx)
|
||||||
movl $1, %edx /* Wake one thread. */
|
movl $1, %edx /* Wake one thread. */
|
||||||
movl $SYS_futex, %eax
|
movl $SYS_futex, %eax
|
||||||
ENTER_KERNEL
|
ENTER_KERNEL
|
||||||
@ -314,6 +328,8 @@ __lll_timedwait_tid:
|
|||||||
jz 4f
|
jz 4f
|
||||||
|
|
||||||
movl %esp, %esi
|
movl %esp, %esi
|
||||||
|
/* XXX The kernel so far uses global futex for the wakeup at
|
||||||
|
all times. */
|
||||||
xorl %ecx, %ecx /* movl $FUTEX_WAIT, %ecx */
|
xorl %ecx, %ecx /* movl $FUTEX_WAIT, %ecx */
|
||||||
movl %ebp, %ebx
|
movl %ebp, %ebx
|
||||||
movl $SYS_futex, %eax
|
movl $SYS_futex, %eax
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 2002, 2003, 2004, 2006 Free Software Foundation, Inc.
|
/* Copyright (C) 2002, 2003, 2004, 2006, 2007 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
|
Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
|
||||||
|
|
||||||
@ -38,6 +38,7 @@
|
|||||||
#define FUTEX_LOCK_PI 6
|
#define FUTEX_LOCK_PI 6
|
||||||
#define FUTEX_UNLOCK_PI 7
|
#define FUTEX_UNLOCK_PI 7
|
||||||
#define FUTEX_TRYLOCK_PI 8
|
#define FUTEX_TRYLOCK_PI 8
|
||||||
|
#define FUTEX_PRIVATE_FLAG 128
|
||||||
|
|
||||||
|
|
||||||
/* Initializer for compatibility lock. */
|
/* Initializer for compatibility lock. */
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 2002, 2003 Free Software Foundation, Inc.
|
/* Copyright (C) 2002, 2003, 2007 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
|
Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
|
||||||
|
|
||||||
@ -19,6 +19,8 @@
|
|||||||
|
|
||||||
#include <unwindbuf.h>
|
#include <unwindbuf.h>
|
||||||
#include <sysdep.h>
|
#include <sysdep.h>
|
||||||
|
#include <kernel-features.h>
|
||||||
|
|
||||||
|
|
||||||
#ifndef UP
|
#ifndef UP
|
||||||
# define LOCK lock
|
# define LOCK lock
|
||||||
@ -26,8 +28,10 @@
|
|||||||
# define LOCK
|
# define LOCK
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define SYS_futex 240
|
#define SYS_futex 240
|
||||||
#define FUTEX_WAKE 1
|
#define FUTEX_WAIT 0
|
||||||
|
#define FUTEX_WAKE 1
|
||||||
|
#define FUTEX_PRIVATE_FLAG 128
|
||||||
|
|
||||||
.comm __fork_generation, 4, 4
|
.comm __fork_generation, 4, 4
|
||||||
|
|
||||||
@ -90,7 +94,16 @@ __pthread_once:
|
|||||||
jnz 3f /* Different for generation -> run initializer. */
|
jnz 3f /* Different for generation -> run initializer. */
|
||||||
|
|
||||||
/* Somebody else got here first. Wait. */
|
/* Somebody else got here first. Wait. */
|
||||||
movl %esi, %ecx /* movl $FUTEX_WAIT, %ecx */
|
#ifdef __ASSUME_PRIVATE_FUTEX
|
||||||
|
movl $FUTEX_WAIT|FUTEX_PRIVATE_FLAG, %ecx
|
||||||
|
#else
|
||||||
|
# if FUTEX_WAIT == 0
|
||||||
|
movl %gs:PRIVATE_FUTEX, %ecx
|
||||||
|
# else
|
||||||
|
movl $FUTEX_WAIT, %ecx
|
||||||
|
orl %gs:PRIVATE_FUTEX, %ecx
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
movl $SYS_futex, %eax
|
movl $SYS_futex, %eax
|
||||||
ENTER_KERNEL
|
ENTER_KERNEL
|
||||||
jmp 6b
|
jmp 6b
|
||||||
@ -131,7 +144,12 @@ __pthread_once:
|
|||||||
|
|
||||||
/* Wake up all other threads. */
|
/* Wake up all other threads. */
|
||||||
movl $0x7fffffff, %edx
|
movl $0x7fffffff, %edx
|
||||||
|
#ifdef __ASSUME_PRIVATE_FUTEX
|
||||||
|
movl $FUTEX_WAKE|FUTEX_PRIVATE_FLAG, %ecx
|
||||||
|
#else
|
||||||
movl $FUTEX_WAKE, %ecx
|
movl $FUTEX_WAKE, %ecx
|
||||||
|
orl %gs:PRIVATE_FUTEX, %ecx
|
||||||
|
#endif
|
||||||
movl $SYS_futex, %eax
|
movl $SYS_futex, %eax
|
||||||
ENTER_KERNEL
|
ENTER_KERNEL
|
||||||
|
|
||||||
@ -152,7 +170,12 @@ __pthread_once:
|
|||||||
movl $0, (%ebx)
|
movl $0, (%ebx)
|
||||||
|
|
||||||
movl $0x7fffffff, %edx
|
movl $0x7fffffff, %edx
|
||||||
|
#ifdef __ASSUME_PRIVATE_FUTEX
|
||||||
|
movl $FUTEX_WAKE|FUTEX_PRIVATE_FLAG, %ecx
|
||||||
|
#else
|
||||||
movl $FUTEX_WAKE, %ecx
|
movl $FUTEX_WAKE, %ecx
|
||||||
|
orl %gs:PRIVATE_FUTEX, %ecx
|
||||||
|
#endif
|
||||||
movl $SYS_futex, %eax
|
movl $SYS_futex, %eax
|
||||||
ENTER_KERNEL
|
ENTER_KERNEL
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 2002, 2003 Free Software Foundation, Inc.
|
/* Copyright (C) 2002, 2003, 2007 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
|
Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
|
||||||
|
|
||||||
@ -17,6 +17,8 @@
|
|||||||
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
||||||
02111-1307 USA. */
|
02111-1307 USA. */
|
||||||
|
|
||||||
|
#include <kernel-features.h>
|
||||||
|
|
||||||
/* In libc.so we do not unconditionally use the lock prefix. Only if
|
/* In libc.so we do not unconditionally use the lock prefix. Only if
|
||||||
the application is using threads. */
|
the application is using threads. */
|
||||||
#ifndef UP
|
#ifndef UP
|
||||||
@ -27,4 +29,17 @@
|
|||||||
0:
|
0:
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* All locks in libc are private. Use the kernel feature if possible. */
|
||||||
|
#define FUTEX_PRIVATE_FLAG 128
|
||||||
|
#ifdef __ASSUME_PRIVATE_FUTEX
|
||||||
|
# define FUTEX_WAIT (0 | FUTEX_PRIVATE_FLAG)
|
||||||
|
# define FUTEX_WAKE (1 | FUTEX_PRIVATE_FLAG)
|
||||||
|
#else
|
||||||
|
# define LOAD_FUTEX_WAIT(reg) \
|
||||||
|
movl %fs:PRIVATE_FUTEX, reg
|
||||||
|
# define LOAD_FUTEX_WAKE(reg) \
|
||||||
|
movl %fs:PRIVATE_FUTEX, reg ; \
|
||||||
|
orl $FUTEX_WAKE, reg
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "lowlevellock.S"
|
#include "lowlevellock.S"
|
||||||
|
@ -31,8 +31,23 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define SYS_futex 202
|
#define SYS_futex 202
|
||||||
#define FUTEX_WAIT 0
|
#ifndef FUTEX_WAIT
|
||||||
#define FUTEX_WAKE 1
|
# define FUTEX_WAIT 0
|
||||||
|
# define FUTEX_WAKE 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef LOAD_FUTEX_WAIT
|
||||||
|
# if FUTEX_WAIT == 0
|
||||||
|
# define LOAD_FUTEX_WAIT(reg) \
|
||||||
|
xorl reg, reg
|
||||||
|
# else
|
||||||
|
# define LOAD_FUTEX_WAIT(reg) \
|
||||||
|
movl $FUTEX_WAIT, reg
|
||||||
|
# endif
|
||||||
|
# define LOAD_FUTEX_WAKE(reg) \
|
||||||
|
movl $FUTEX_WAKE, reg
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* For the calculation see asm/vsyscall.h. */
|
/* For the calculation see asm/vsyscall.h. */
|
||||||
#define VSYSCALL_ADDR_vgettimeofday 0xffffffffff600000
|
#define VSYSCALL_ADDR_vgettimeofday 0xffffffffff600000
|
||||||
@ -52,11 +67,7 @@ __lll_mutex_lock_wait:
|
|||||||
cfi_offset(%rdx, -24)
|
cfi_offset(%rdx, -24)
|
||||||
xorq %r10, %r10 /* No timeout. */
|
xorq %r10, %r10 /* No timeout. */
|
||||||
movl $2, %edx
|
movl $2, %edx
|
||||||
#if FUTEX_WAIT == 0
|
LOAD_FUTEX_WAIT (%esi)
|
||||||
xorl %esi, %esi
|
|
||||||
#else
|
|
||||||
movl $FUTEX_WAIT, %esi
|
|
||||||
#endif
|
|
||||||
|
|
||||||
cmpl %edx, %eax /* NB: %edx == 2 */
|
cmpl %edx, %eax /* NB: %edx == 2 */
|
||||||
jne 2f
|
jne 2f
|
||||||
@ -151,11 +162,7 @@ __lll_mutex_timedlock_wait:
|
|||||||
je 8f
|
je 8f
|
||||||
|
|
||||||
movq %rsp, %r10
|
movq %rsp, %r10
|
||||||
#if FUTEX_WAIT == 0
|
LOAD_FUTEX_WAIT (%esi)
|
||||||
xorl %esi, %esi
|
|
||||||
#else
|
|
||||||
movl $FUTEX_WAIT, %esi
|
|
||||||
#endif
|
|
||||||
movq %r12, %rdi
|
movq %r12, %rdi
|
||||||
movl $SYS_futex, %eax
|
movl $SYS_futex, %eax
|
||||||
syscall
|
syscall
|
||||||
@ -247,7 +254,7 @@ __lll_mutex_unlock_wake:
|
|||||||
cfi_offset(%rdx, -24)
|
cfi_offset(%rdx, -24)
|
||||||
|
|
||||||
movl $0, (%rdi)
|
movl $0, (%rdi)
|
||||||
movl $FUTEX_WAKE, %esi
|
LOAD_FUTEX_WAKE (%esi)
|
||||||
movl $1, %edx /* Wake one thread. */
|
movl $1, %edx /* Wake one thread. */
|
||||||
movl $SYS_futex, %eax
|
movl $SYS_futex, %eax
|
||||||
syscall
|
syscall
|
||||||
@ -311,6 +318,8 @@ __lll_timedwait_tid:
|
|||||||
jz 4f
|
jz 4f
|
||||||
|
|
||||||
movq %rsp, %r10
|
movq %rsp, %r10
|
||||||
|
/* XXX The kernel so far uses global futex for the wakeup at
|
||||||
|
all times. */
|
||||||
#if FUTEX_WAIT == 0
|
#if FUTEX_WAIT == 0
|
||||||
xorl %esi, %esi
|
xorl %esi, %esi
|
||||||
#else
|
#else
|
||||||
|
@ -39,6 +39,7 @@
|
|||||||
#define FUTEX_LOCK_PI 6
|
#define FUTEX_LOCK_PI 6
|
||||||
#define FUTEX_UNLOCK_PI 7
|
#define FUTEX_UNLOCK_PI 7
|
||||||
#define FUTEX_TRYLOCK_PI 8
|
#define FUTEX_TRYLOCK_PI 8
|
||||||
|
#define FUTEX_PRIVATE_FLAG 128
|
||||||
|
|
||||||
|
|
||||||
/* Initializer for compatibility lock. */
|
/* Initializer for compatibility lock. */
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 2002, 2003, 2005 Free Software Foundation, Inc.
|
/* Copyright (C) 2002, 2003, 2005, 2007 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
|
Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
|
||||||
|
|
||||||
@ -17,14 +17,19 @@
|
|||||||
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
||||||
02111-1307 USA. */
|
02111-1307 USA. */
|
||||||
|
|
||||||
|
#include <kernel-features.h>
|
||||||
|
#include <tcb-offsets.h>
|
||||||
|
|
||||||
#ifndef UP
|
#ifndef UP
|
||||||
# define LOCK lock
|
# define LOCK lock
|
||||||
#else
|
#else
|
||||||
# define LOCK
|
# define LOCK
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define SYS_futex 202
|
#define SYS_futex 202
|
||||||
#define FUTEX_WAKE 1
|
#define FUTEX_WAIT 0
|
||||||
|
#define FUTEX_WAKE 1
|
||||||
|
#define FUTEX_PRIVATE_FLAG 128
|
||||||
|
|
||||||
.comm __fork_generation, 4, 4
|
.comm __fork_generation, 4, 4
|
||||||
|
|
||||||
@ -74,10 +79,15 @@ __pthread_once:
|
|||||||
jnz 3f /* Different for generation -> run initializer. */
|
jnz 3f /* Different for generation -> run initializer. */
|
||||||
|
|
||||||
/* Somebody else got here first. Wait. */
|
/* Somebody else got here first. Wait. */
|
||||||
#if FUTEX_WAIT == 0
|
#ifdef __ASSUME_PRIVATE_FUTEX
|
||||||
xorl %esi, %esi
|
movl $FUTEX_WAIT|FUTEX_PRIVATE_FLAG, %esi
|
||||||
#else
|
#else
|
||||||
|
# if FUTEX_WAIT == 0
|
||||||
|
movl %fs:PRIVATE_FUTEX, %esi
|
||||||
|
# else
|
||||||
movl $FUTEX_WAIT, %esi
|
movl $FUTEX_WAIT, %esi
|
||||||
|
orl %fs:PRIVATE_FUTEX, %esi
|
||||||
|
# endif
|
||||||
#endif
|
#endif
|
||||||
movl $SYS_futex, %eax
|
movl $SYS_futex, %eax
|
||||||
syscall
|
syscall
|
||||||
@ -106,7 +116,12 @@ __pthread_once:
|
|||||||
|
|
||||||
/* Wake up all other threads. */
|
/* Wake up all other threads. */
|
||||||
movl $0x7fffffff, %edx
|
movl $0x7fffffff, %edx
|
||||||
|
#ifdef __ASSUME_PRIVATE_FUTEX
|
||||||
|
movl $FUTEX_WAKE|FUTEX_PRIVATE_FLAG, %esi
|
||||||
|
#else
|
||||||
movl $FUTEX_WAKE, %esi
|
movl $FUTEX_WAKE, %esi
|
||||||
|
orl %fs:PRIVATE_FUTEX, %esi
|
||||||
|
#endif
|
||||||
movl $SYS_futex, %eax
|
movl $SYS_futex, %eax
|
||||||
syscall
|
syscall
|
||||||
|
|
||||||
@ -133,7 +148,12 @@ clear_once_control:
|
|||||||
movl $0, (%rdi)
|
movl $0, (%rdi)
|
||||||
|
|
||||||
movl $0x7fffffff, %edx
|
movl $0x7fffffff, %edx
|
||||||
|
#ifdef __ASSUME_PRIVATE_FUTEX
|
||||||
|
movl $FUTEX_WAKE|FUTEX_PRIVATE_FLAG, %esi
|
||||||
|
#else
|
||||||
movl $FUTEX_WAKE, %esi
|
movl $FUTEX_WAKE, %esi
|
||||||
|
orl %fs:PRIVATE_FUTEX, %esi
|
||||||
|
#endif
|
||||||
movl $SYS_futex, %eax
|
movl $SYS_futex, %eax
|
||||||
syscall
|
syscall
|
||||||
|
|
||||||
|
@ -12,3 +12,6 @@ MUTEX_FUTEX offsetof (pthread_mutex_t, __data.__lock)
|
|||||||
MULTIPLE_THREADS_OFFSET offsetof (tcbhead_t, multiple_threads)
|
MULTIPLE_THREADS_OFFSET offsetof (tcbhead_t, multiple_threads)
|
||||||
POINTER_GUARD offsetof (tcbhead_t, pointer_guard)
|
POINTER_GUARD offsetof (tcbhead_t, pointer_guard)
|
||||||
VGETCPU_CACHE_OFFSET offsetof (tcbhead_t, vgetcpu_cache)
|
VGETCPU_CACHE_OFFSET offsetof (tcbhead_t, vgetcpu_cache)
|
||||||
|
#ifndef __ASSUME_PRIVATE_FUTEX
|
||||||
|
PRIVATE_FUTEX offsetof (tcbhead_t, private_futex)
|
||||||
|
#endif
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
# include <stdint.h>
|
# include <stdint.h>
|
||||||
# include <stdlib.h>
|
# include <stdlib.h>
|
||||||
# include <sysdep.h>
|
# include <sysdep.h>
|
||||||
|
# include <kernel-features.h>
|
||||||
|
|
||||||
|
|
||||||
/* Type for the dtv. */
|
/* Type for the dtv. */
|
||||||
@ -53,6 +54,9 @@ typedef struct
|
|||||||
uintptr_t stack_guard;
|
uintptr_t stack_guard;
|
||||||
uintptr_t pointer_guard;
|
uintptr_t pointer_guard;
|
||||||
unsigned long int vgetcpu_cache[2];
|
unsigned long int vgetcpu_cache[2];
|
||||||
|
#ifndef __ASSUME_PRIVATE_FUTEX
|
||||||
|
int private_futex;
|
||||||
|
#endif
|
||||||
} tcbhead_t;
|
} tcbhead_t;
|
||||||
|
|
||||||
#else /* __ASSEMBLER__ */
|
#else /* __ASSEMBLER__ */
|
||||||
|
Loading…
Reference in New Issue
Block a user