From: Luis Machado Date: Wed, 24 Mar 2010 21:46:03 +0000 (-0700) Subject: Enable common version of pthread_cond_timedwait to use clock_gettime in VDSO X-Git-Tag: fedora/glibc-2.11.90-17~2^2~53 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=7749bf5fe6ac0464db10a3a17a31121517f92530;p=thirdparty%2Fglibc.git Enable common version of pthread_cond_timedwait to use clock_gettime in VDSO --- diff --git a/nptl/ChangeLog b/nptl/ChangeLog index f51ad432650..bab38c7a8f6 100644 --- a/nptl/ChangeLog +++ b/nptl/ChangeLog @@ -1,3 +1,10 @@ +2010-03-23 Luis Machado + + * pthread_cond_timedwait.c: Add check for + HAVE_CLOCK_GETTIME_VSYSCALL to use VDSO whenever possible. + (pthread_cond_timedwait): Use INTERNAL_VSYSCALL instead of + INTERNAL_SYSCALL. + 2010-03-09 Ulrich Drepper * pthread_create.c (__pthread_create_2_1): If priorities are incorrect diff --git a/nptl/pthread_cond_timedwait.c b/nptl/pthread_cond_timedwait.c index 9d268e911e0..7278ec45b0e 100644 --- a/nptl/pthread_cond_timedwait.c +++ b/nptl/pthread_cond_timedwait.c @@ -1,4 +1,4 @@ -/* Copyright (C) 2003, 2004, 2007 Free Software Foundation, Inc. +/* Copyright (C) 2003, 2004, 2007, 2010 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Martin Schwidefsky , 2003. @@ -27,6 +27,14 @@ #include +#ifndef HAVE_CLOCK_GETTIME_VSYSCALL +# undef INTERNAL_VSYSCALL +# define INTERNAL_VSYSCALL INTERNAL_SYSCALL +# undef INLINE_VSYSCALL +# define INLINE_VSYSCALL INLINE_SYSCALL +#else +# include +#endif /* Cleanup handler, defined in pthread_cond_wait.c. */ extern void __condvar_cleanup (void *arg) @@ -102,7 +110,7 @@ __pthread_cond_timedwait (cond, mutex, abstime) #ifdef __NR_clock_gettime INTERNAL_SYSCALL_DECL (err); int ret; - ret = INTERNAL_SYSCALL (clock_gettime, err, 2, + ret = INTERNAL_VSYSCALL (clock_gettime, err, 2, (cond->__data.__nwaiters & ((1 << COND_NWAITERS_SHIFT) - 1)), &rt);