Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristopher Faylor <me@cgf.cx>2005-03-06 23:21:30 +0300
committerChristopher Faylor <me@cgf.cx>2005-03-06 23:21:30 +0300
commit3f02a8d0f4ca99d7e82fb678db8d50819ce4156e (patch)
tree4a286194ec404b446526d9c27542eea27ac01aab /winsup/cygwin/sync.cc
parenta50b6b2dcd76cfb494617c37f93ebed175d60560 (diff)
* sync.h (sync::init_lock): Declare new static member.
(sync::init()): Declare new static function. * sync.cc (sync::init): Define. (sync::init): Lock attempt to initialize a muto to stop multiple threads from colliding. * dcrt0.cc (dll_crt0_0): Initialize muto environment.
Diffstat (limited to 'winsup/cygwin/sync.cc')
-rw-r--r--winsup/cygwin/sync.cc29
1 files changed, 22 insertions, 7 deletions
diff --git a/winsup/cygwin/sync.cc b/winsup/cygwin/sync.cc
index a7994048d..f946bc705 100644
--- a/winsup/cygwin/sync.cc
+++ b/winsup/cygwin/sync.cc
@@ -28,6 +28,13 @@ details. */
#undef WaitForSingleObject
DWORD NO_COPY muto::exiting_thread;
+CRITICAL_SECTION NO_COPY muto::init_lock;
+
+void
+muto::init ()
+{
+ InitializeCriticalSection (&init_lock);
+}
void
muto::grab ()
@@ -39,15 +46,23 @@ muto::grab ()
muto *
muto::init (const char *s)
{
- waiters = -1;
- /* Create event which is used in the fallback case when blocking is necessary */
- if (!(bruteforce = CreateEvent (&sec_none_nih, FALSE, FALSE, NULL)))
+ muto *res = this;
+ EnterCriticalSection (&init_lock);
+ if (!bruteforce)
{
- DWORD oerr = GetLastError ();
- SetLastError (oerr);
- return NULL;
+ waiters = -1;
+ bruteforce = CreateEvent (&sec_none_nih, FALSE, FALSE, NULL);
+ /* Create event which is used in the fallback case when blocking is necessary */
+ if (bruteforce)
+ name = s;
+ else
+ {
+ DWORD oerr = GetLastError ();
+ SetLastError (oerr);
+ res = NULL;
+ }
}
- name = s;
+ LeaveCriticalSection (&init_lock);
return this;
}