diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2005-09-06 19:22:54 +0000 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2005-09-06 19:22:54 +0000 |
commit | 75833f08cd845632e2706cdbcc1df86607f73117 (patch) | |
tree | 693bb99e2d9c2f75a991fe1dd3cc1b7f0b246b17 /winsup/cygwin/thread.h | |
parent | 5843726e51e0cc7463e6c271febe5b40025b9b6e (diff) | |
download | cygnal-75833f08cd845632e2706cdbcc1df86607f73117.tar.gz cygnal-75833f08cd845632e2706cdbcc1df86607f73117.tar.bz2 cygnal-75833f08cd845632e2706cdbcc1df86607f73117.zip |
* thread.h: Revert patch from 2005-09-05.
* thread.cc (pthread_mutex::can_be_unlocked): Return true also if
mutex is owned by MUTEX_OWNER_ANONYMOUS.
Diffstat (limited to 'winsup/cygwin/thread.h')
-rw-r--r-- | winsup/cygwin/thread.h | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/winsup/cygwin/thread.h b/winsup/cygwin/thread.h index f8ab9da8b..c15ded478 100644 --- a/winsup/cygwin/thread.h +++ b/winsup/cygwin/thread.h @@ -301,21 +301,27 @@ public: int type; int pshared; + pthread_t get_pthread_self () const + { + return PTHREAD_MUTEX_NORMAL == type ? MUTEX_OWNER_ANONYMOUS : + ::pthread_self (); + } + int lock () { - return _lock (::pthread_self ()); + return _lock (get_pthread_self ()); } int trylock () { - return _trylock (::pthread_self ()); + return _trylock (get_pthread_self ()); } int unlock () { - return _unlock (::pthread_self ()); + return _unlock (get_pthread_self ()); } int destroy () { - return _destroy (::pthread_self ()); + return _destroy (get_pthread_self ()); } void set_owner (pthread_t self) |