summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--winsup/cygwin/ChangeLog6
-rw-r--r--winsup/cygwin/shared.cc14
2 files changed, 13 insertions, 7 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog
index 33b7c6c38..9153680cc 100644
--- a/winsup/cygwin/ChangeLog
+++ b/winsup/cygwin/ChangeLog
@@ -1,3 +1,9 @@
+2011-10-24 Corinna Vinschen <corinna@vinschen.de>
+
+ * shared.cc (open_shared): Fix memory reservation of essential shared
+ memory regions. Drop delta computations since delta is always 0 in
+ non-relocated case. Add a comment.
+
2011-10-23 Christopher Faylor <me.cygwin2011@cgf.cx>
* fhandler_tty.cc (fhandler_pty_slave::read): Use consistent way for
diff --git a/winsup/cygwin/shared.cc b/winsup/cygwin/shared.cc
index b38beb971..b98c13651 100644
--- a/winsup/cygwin/shared.cc
+++ b/winsup/cygwin/shared.cc
@@ -293,19 +293,19 @@ open_shared (const WCHAR *name, int n, HANDLE& shared_h, DWORD size,
if (*m == SH_CYGWIN_SHARED && offsets[0])
{
- ptrdiff_t delta = (caddr_t) shared - (caddr_t) off_addr (0);
- offsets[0] = (caddr_t) shared - (caddr_t) cygwin_hmodule;
- for (int i = SH_USER_SHARED + 1; i < SH_TOTAL_SIZE; i++)
+ /* Reserve subsequent shared memory areas in non-relocated case only.
+ There's no good reason to reserve the console shmem, because it's
+ not yet known if we will allocate it at all. */
+ for (int i = SH_USER_SHARED; i < SH_SHARED_CONSOLE; i++)
{
- unsigned size = offsets[i] - offsets[i + 1];
- offsets[i] += delta;
+ DWORD size = offsets[i - 1] - offsets[i];
if (!VirtualAlloc (off_addr (i), size, MEM_RESERVE, PAGE_NOACCESS))
continue; /* oh well */
}
- offsets[SH_TOTAL_SIZE] += delta;
}
- debug_printf ("name %W, n %d, shared %p (wanted %p), h %p, *m %d", mapname, n, shared, addr, shared_h, *m);
+ debug_printf ("name %W, n %d, shared %p (wanted %p), h %p, *m %d",
+ mapname, n, shared, addr, shared_h, *m);
return shared;
}