cygwin: Implement pthread_rwlock_timedrdlock, pthread_rwlock_timedwrlock
Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
This commit is contained in:
		
							parent
							
								
									eb206317a8
								
							
						
					
					
						commit
						8128f5482f
					
				|  | @ -1085,6 +1085,8 @@ pthread_once SIGFE | |||
| pthread_rwlock_destroy SIGFE | ||||
| pthread_rwlock_init SIGFE | ||||
| pthread_rwlock_rdlock SIGFE | ||||
| pthread_rwlock_timedrdlock SIGFE | ||||
| pthread_rwlock_timedwrlock SIGFE | ||||
| pthread_rwlock_tryrdlock SIGFE | ||||
| pthread_rwlock_trywrlock SIGFE | ||||
| pthread_rwlock_unlock SIGFE | ||||
|  |  | |||
|  | @ -480,12 +480,13 @@ details. */ | |||
|   313: Export fls, flsl, flsll. | ||||
|   314: Export explicit_bzero. | ||||
|   315: Export pthread_mutex_timedlock. | ||||
|   316: Export pthread_rwlock_timedrdlock, pthread_rwlock_timedwrlock. | ||||
| 
 | ||||
|   Note that we forgot to bump the api for ualarm, strtoll, strtoull, | ||||
|   sigaltstack, sethostname. */ | ||||
| 
 | ||||
| #define CYGWIN_VERSION_API_MAJOR 0 | ||||
| #define CYGWIN_VERSION_API_MINOR 315 | ||||
| #define CYGWIN_VERSION_API_MINOR 316 | ||||
| 
 | ||||
| /* There is also a compatibity version number associated with the shared memory
 | ||||
|    regions.  It is incremented when incompatible changes are made to the shared | ||||
|  |  | |||
|  | @ -1,7 +1,10 @@ | |||
| What's new: | ||||
| ----------- | ||||
| 
 | ||||
| - New APIs: explicit_bzero, pthread_mutex_timedwait. | ||||
| - New APIs: explicit_bzero. | ||||
| 
 | ||||
| - New APIs: pthread_mutex_timedwait, pthread_rwlock_timedrdlock, | ||||
| 	    pthread_rwlock_timedwrlock. | ||||
| 
 | ||||
| 
 | ||||
| What changed: | ||||
|  |  | |||
|  | @ -1413,7 +1413,7 @@ pthread_rwlock::~pthread_rwlock () | |||
| } | ||||
| 
 | ||||
| int | ||||
| pthread_rwlock::rdlock () | ||||
| pthread_rwlock::rdlock (PLARGE_INTEGER timeout) | ||||
| { | ||||
|   int result = 0; | ||||
|   struct RWLOCK_READER *reader; | ||||
|  | @ -1435,7 +1435,7 @@ pthread_rwlock::rdlock () | |||
|       pthread_cleanup_push (pthread_rwlock::rdlock_cleanup, this); | ||||
| 
 | ||||
|       ++waiting_readers; | ||||
|       cond_readers.wait (&mtx); | ||||
|       cond_readers.wait (&mtx, timeout); | ||||
|       --waiting_readers; | ||||
| 
 | ||||
|       pthread_cleanup_pop (0); | ||||
|  | @ -1481,7 +1481,7 @@ pthread_rwlock::tryrdlock () | |||
| } | ||||
| 
 | ||||
| int | ||||
| pthread_rwlock::wrlock () | ||||
| pthread_rwlock::wrlock (PLARGE_INTEGER timeout) | ||||
| { | ||||
|   int result = 0; | ||||
|   pthread_t self = pthread::self (); | ||||
|  | @ -1499,7 +1499,7 @@ pthread_rwlock::wrlock () | |||
|       pthread_cleanup_push (pthread_rwlock::wrlock_cleanup, this); | ||||
| 
 | ||||
|       ++waiting_writers; | ||||
|       cond_writers.wait (&mtx); | ||||
|       cond_writers.wait (&mtx, timeout); | ||||
|       --waiting_writers; | ||||
| 
 | ||||
|       pthread_cleanup_pop (0); | ||||
|  | @ -3045,6 +3045,37 @@ pthread_rwlock_rdlock (pthread_rwlock_t *rwlock) | |||
|   return (*rwlock)->rdlock (); | ||||
| } | ||||
| 
 | ||||
| extern "C" int | ||||
| pthread_rwlock_timedrdlock (pthread_rwlock_t *rwlock, | ||||
| 			    const struct timespec *abstime) | ||||
| { | ||||
|   LARGE_INTEGER timeout; | ||||
| 
 | ||||
|   pthread_testcancel (); | ||||
| 
 | ||||
|   if (pthread_rwlock::is_initializer (rwlock)) | ||||
|     pthread_rwlock::init (rwlock, NULL); | ||||
|   if (!pthread_rwlock::is_good_object (rwlock)) | ||||
|     return EINVAL; | ||||
| 
 | ||||
|   /* According to SUSv3, abstime need not be checked for validity,
 | ||||
|      if the rwlock can be locked immediately. */ | ||||
|   if (!(*rwlock)->tryrdlock ()) | ||||
|     return 0; | ||||
| 
 | ||||
|   __try | ||||
|     { | ||||
|       int err = pthread_convert_abstime (CLOCK_REALTIME, abstime, &timeout); | ||||
|       if (err) | ||||
| 	return err; | ||||
| 
 | ||||
|       return (*rwlock)->rdlock (&timeout); | ||||
|     } | ||||
|   __except (NO_ERROR) {} | ||||
|   __endtry | ||||
|   return EINVAL; | ||||
| } | ||||
| 
 | ||||
| extern "C" int | ||||
| pthread_rwlock_tryrdlock (pthread_rwlock_t *rwlock) | ||||
| { | ||||
|  | @ -3069,6 +3100,37 @@ pthread_rwlock_wrlock (pthread_rwlock_t *rwlock) | |||
|   return (*rwlock)->wrlock (); | ||||
| } | ||||
| 
 | ||||
| extern "C" int | ||||
| pthread_rwlock_timedwrlock (pthread_rwlock_t *rwlock, | ||||
| 			    const struct timespec *abstime) | ||||
| { | ||||
|   LARGE_INTEGER timeout; | ||||
| 
 | ||||
|   pthread_testcancel (); | ||||
| 
 | ||||
|   if (pthread_rwlock::is_initializer (rwlock)) | ||||
|     pthread_rwlock::init (rwlock, NULL); | ||||
|   if (!pthread_rwlock::is_good_object (rwlock)) | ||||
|     return EINVAL; | ||||
| 
 | ||||
|   /* According to SUSv3, abstime need not be checked for validity,
 | ||||
|      if the rwlock can be locked immediately. */ | ||||
|   if (!(*rwlock)->trywrlock ()) | ||||
|     return 0; | ||||
| 
 | ||||
|   __try | ||||
|     { | ||||
|       int err = pthread_convert_abstime (CLOCK_REALTIME, abstime, &timeout); | ||||
|       if (err) | ||||
| 	return err; | ||||
| 
 | ||||
|       return (*rwlock)->wrlock (&timeout); | ||||
|     } | ||||
|   __except (NO_ERROR) {} | ||||
|   __endtry | ||||
|   return EINVAL; | ||||
| } | ||||
| 
 | ||||
| extern "C" int | ||||
| pthread_rwlock_trywrlock (pthread_rwlock_t *rwlock) | ||||
| { | ||||
|  |  | |||
|  | @ -587,10 +587,10 @@ public: | |||
|   } *readers; | ||||
|   fast_mutex readers_mx; | ||||
| 
 | ||||
|   int rdlock (); | ||||
|   int rdlock (PLARGE_INTEGER timeout = NULL); | ||||
|   int tryrdlock (); | ||||
| 
 | ||||
|   int wrlock (); | ||||
|   int wrlock (PLARGE_INTEGER timeout = NULL); | ||||
|   int trywrlock (); | ||||
| 
 | ||||
|   int unlock (); | ||||
|  |  | |||
|  | @ -9,7 +9,12 @@ | |||
| <itemizedlist mark="bullet"> | ||||
| 
 | ||||
| <listitem><para> | ||||
| New APIs: explicit_bzero, pthread_mutex_timedwait. | ||||
| New APIs: explicit_bzero. | ||||
| </para></listitem> | ||||
| 
 | ||||
| <listitem><para> | ||||
| New APIs: pthread_mutex_timedwait, pthread_rwlock_timedrdlock, | ||||
| pthread_rwlock_timedwrlock. | ||||
| </para></listitem> | ||||
| 
 | ||||
| <listitem><para> | ||||
|  |  | |||
|  | @ -723,6 +723,8 @@ also IEEE Std 1003.1-2008 (POSIX.1-2008).</para> | |||
|     pthread_rwlock_destroy | ||||
|     pthread_rwlock_init | ||||
|     pthread_rwlock_rdlock | ||||
|     pthread_rwlock_timedrdlock | ||||
|     pthread_rwlock_timedwrlock | ||||
|     pthread_rwlock_tryrdlock | ||||
|     pthread_rwlock_trywrlock | ||||
|     pthread_rwlock_unlock | ||||
|  | @ -1575,8 +1577,6 @@ also IEEE Std 1003.1-2008 (POSIX.1-2008).</para> | |||
|     pthread_mutexattr_getrobust | ||||
|     pthread_mutexattr_setrobust | ||||
|     pthread_mutex_consistent | ||||
|     pthread_rwlock_timedrdlock | ||||
|     pthread_rwlock_timedwrlock | ||||
|     putmsg | ||||
|     setnetent | ||||
|     sigtimedwait | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue