summaryrefslogtreecommitdiffstats
path: root/winsup/cygserver/bsd_mutex.cc
diff options
context:
space:
mode:
authorCorinna Vinschen <corinna@vinschen.de>2004-07-30 14:48:19 +0000
committerCorinna Vinschen <corinna@vinschen.de>2004-07-30 14:48:19 +0000
commita918549275fd4e07362ec55cbabdaaaa12697dec (patch)
tree59f84da70f0b24d1115e6b992d9d9b90af2a6104 /winsup/cygserver/bsd_mutex.cc
parentf048a4a16f61132a00bc32bc92433134749a47ab (diff)
downloadcygnal-a918549275fd4e07362ec55cbabdaaaa12697dec.tar.gz
cygnal-a918549275fd4e07362ec55cbabdaaaa12697dec.tar.bz2
cygnal-a918549275fd4e07362ec55cbabdaaaa12697dec.zip
* bsd_mutex.cc (_msleep): Reset event object and close it before
entering mutex. Turn order of conditional for better readability.
Diffstat (limited to 'winsup/cygserver/bsd_mutex.cc')
-rw-r--r--winsup/cygserver/bsd_mutex.cc6
1 files changed, 4 insertions, 2 deletions
diff --git a/winsup/cygserver/bsd_mutex.cc b/winsup/cygserver/bsd_mutex.cc
index 1a01dd2ea..449e61449 100644
--- a/winsup/cygserver/bsd_mutex.cc
+++ b/winsup/cygserver/bsd_mutex.cc
@@ -222,10 +222,12 @@ _msleep (void *ident, struct mtx *mtx, int priority,
panic ("wait in msleep (%s) failed, %E", wmesg);
break;
}
+ /* Dismiss event before entering mutex. */
+ ResetEvent (evt);
+ CloseHandle (evt);
set_priority (old_priority);
- if (!(priority & PDROP) && mtx)
+ if (mtx && !(priority & PDROP))
mtx_lock (mtx);
- CloseHandle (evt);
return ret;
}