about summary refs log tree commit diff
path: root/nptl/sysdeps/pthread/pthread_cond_timedwait.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2003-03-18 11:17:57 +0000
committerUlrich Drepper <drepper@redhat.com>2003-03-18 11:17:57 +0000
commit86a9ee5e87cc084ccce131cd51166c98ea87f28f (patch)
tree66fc7276b0bd25d53b007efe496c330a6725adfc /nptl/sysdeps/pthread/pthread_cond_timedwait.c
parent4773086e0498c99ee11422fc39606e9a53f12502 (diff)
downloadglibc-86a9ee5e87cc084ccce131cd51166c98ea87f28f.tar.gz
glibc-86a9ee5e87cc084ccce131cd51166c98ea87f28f.tar.xz
glibc-86a9ee5e87cc084ccce131cd51166c98ea87f28f.zip
Update.
2003-03-18  Ulrich Drepper  <drepper@redhat.com>

	* pthread_condattr_getclock.c: New file.
	* pthread_condattr_setclock.c: New file.
	* sysdeps/pthread/pthread.h: Declare these new functions.
	* Versions [GLIBC_2.3.3] (libpthread): Add the new functions.
	* Makefile (libpthread-routines): Add the new functions.
	* sysdeps/unix/sysv/linux/internaltypes.h (struct pthread_condattr):
	Renamed field to value.  Document use of the bits.
	* pthread_condattr_getpshared.c: Adjust for struct pthread_condattr
	change.
	* pthread_condattr_setpshared.c: Likewise.
	* sysdeps/unix/sysv/linux/lowlevelcond.sym: Add cond_clock symbol.
	* sysdeps/unix/sysv/linux/i386/bits/pthreadtypes.h (pthread_cond_t):
	Add __clock field.
	* sysdeps/unix/sysv/linux/ia64/bits/pthreadtypes.h: Likewise.
	* sysdeps/unix/sysv/linux/powerpc/bits/pthreadtypes.h: Likewise.
	* sysdeps/unix/sysv/linux/s390/bits/pthreadtypes.h: Likewise.
	* sysdeps/unix/sysv/linux/sh/bits/pthreadtypes.h: Likewise.
	* sysdeps/unix/sysv/linux/i386/i486/pthread_cond_timedwait.S:
	Implement clock selection.
	* sysdeps/pthread/pthread_cond_timedwait.c: Likewise.
	* pthread-errnos.sym: Add ENOSYS.
	* sysdeps/unix/sysv/linux/bits/posix_opt.h: Define
	_POSIX_CLOCK_SELECTION.
	* sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.

	* sysdeps/unix/sysv/linux/x86_64/pthread_cond_timedwait.S: Remove
	invalid .size directive.
Diffstat (limited to 'nptl/sysdeps/pthread/pthread_cond_timedwait.c')
-rw-r--r--nptl/sysdeps/pthread/pthread_cond_timedwait.c25
1 files changed, 24 insertions, 1 deletions
diff --git a/nptl/sysdeps/pthread/pthread_cond_timedwait.c b/nptl/sysdeps/pthread/pthread_cond_timedwait.c
index af9929c500..e0200b4cd8 100644
--- a/nptl/sysdeps/pthread/pthread_cond_timedwait.c
+++ b/nptl/sysdeps/pthread/pthread_cond_timedwait.c
@@ -92,14 +92,37 @@ __pthread_cond_timedwait (cond, mutex, abstime)
 
   while (1)
     {
+      struct timespec rt;
+#ifdef __NR_clock_gettime
+      INTERNAL_SYSCALL_DECL (err);
+      int val = INTERNAL_SYSCALL (clock_gettime, err, 2, cond->__data.__clock,
+				  &ts);
+# ifndef __ASSUME_POSIX_TIMERS
+      if (__builtin_expect (INTERNAL_SYSCALL_ERROR_P (val, err), 0))
+	{
+	  struct timeval tv;
+	  (void) gettimeofday (&tv, NULL);
+
+	  /* Convert the absolute timeout value to a relative timeout.  */
+	  rt.tv_sec = abstime->tv_sec - tv.tv_sec;
+	  rt.tv_nsec = abstime->tv_nsec - tv.tv_usec * 1000;
+	}
+      else
+# endif
+	{
+	  /* Convert the absolute timeout value to a relative timeout.  */
+	  rt.tv_sec = abstime->tv_sec - rt.tv_sec;
+	  rt.tv_nsec = abstime->tv_nsec - rt.tv_nsec;
+	}
+#else
       /* Get the current time.  So far we support only one clock.  */
       struct timeval tv;
       (void) gettimeofday (&tv, NULL);
 
       /* Convert the absolute timeout value to a relative timeout.  */
-      struct timespec rt;
       rt.tv_sec = abstime->tv_sec - tv.tv_sec;
       rt.tv_nsec = abstime->tv_nsec - tv.tv_usec * 1000;
+#endif
       if (rt.tv_nsec < 0)
 	{
 	  rt.tv_nsec += 1000000000;