aboutsummaryrefslogtreecommitdiff
path: root/winsup
diff options
context:
space:
mode:
authorCorinna Vinschen <corinna@vinschen.de>2006-08-11 15:40:07 +0000
committerCorinna Vinschen <corinna@vinschen.de>2006-08-11 15:40:07 +0000
commite39a29e36b46bcc6bdbb7952872a33375b13d35a (patch)
treeb6ecc1172f0181beaae2ba485014bfaf014cc5c6 /winsup
parentfc43c1d925e8b520e33bfc2aa1494e3d14791684 (diff)
downloadnewlib-e39a29e36b46bcc6bdbb7952872a33375b13d35a.zip
newlib-e39a29e36b46bcc6bdbb7952872a33375b13d35a.tar.gz
newlib-e39a29e36b46bcc6bdbb7952872a33375b13d35a.tar.bz2
* shared.cc (open_shared): Desperately try to get shared memory, only
when DEBUGGING enabled for now.
Diffstat (limited to 'winsup')
-rw-r--r--winsup/cygwin/ChangeLog5
-rw-r--r--winsup/cygwin/shared.cc24
2 files changed, 29 insertions, 0 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog
index 8aed544..857f1e7 100644
--- a/winsup/cygwin/ChangeLog
+++ b/winsup/cygwin/ChangeLog
@@ -1,3 +1,8 @@
+2006-08-11 Corinna Vinschen <corinna@vinschen.de>
+
+ * shared.cc (open_shared): Desperately try to get shared memory, only
+ when DEBUGGING enabled for now.
+
2006-08-10 Christopher Faylor <cgf@timesys.com>
* pinfo.cc (_onreturn::~onreturn): Don't attempt to close a NULL
diff --git a/winsup/cygwin/shared.cc b/winsup/cygwin/shared.cc
index 65965b5..2524eca 100644
--- a/winsup/cygwin/shared.cc
+++ b/winsup/cygwin/shared.cc
@@ -93,6 +93,30 @@ open_shared (const char *name, int n, HANDLE& shared_h, DWORD size,
{
shared_h = CreateFileMapping (INVALID_HANDLE_VALUE, psa, PAGE_READWRITE,
0, size, mapname);
+#ifdef DEBUGGING
+ if (!shared_h && GetLastError () == NO_ERROR)
+ {
+ system_printf ("CreateFileMapping %s, %E. Retry Open", mapname);
+ shared_h = OpenFileMapping (access, FALSE, mapname);
+ if (!shared_h)
+ {
+ system_printf ("OpenFileMapping %s, %E. Retry Create "
+ "after sleep (check timing problem)", mapname);
+ Sleep (1000L);
+ shared_h = CreateFileMapping (INVALID_HANDLE_VALUE, psa,
+ PAGE_READWRITE, 0, size,
+ mapname);
+ if (!shared_h)
+ system_printf ("Retried CreateFileMapping %s, %E.",
+ mapname);
+ else
+ system_printf ("Retried CreateFileMapping %s succeeded!",
+ mapname);
+ }
+ else
+ system_printf ("OpenFileMapping %s succeeded!", mapname);
+ }
+#endif
if (GetLastError () == ERROR_ALREADY_EXISTS)
m = SH_JUSTOPEN;
}