Cygwin: open_shared: don't reuse shared_locations parameter as output
For ages, open_shared uses the shared_locations parameter as output to indicate if the mapping for a shared region has been created or just opened. Split this into two parameters. Use the shared_locations parameter as input only, return the creation state of the mapping in a bool reference parameter. Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
This commit is contained in:
parent
77680cac94
commit
93508e5bb8
|
@ -211,15 +211,14 @@ beep ()
|
||||||
}
|
}
|
||||||
|
|
||||||
fhandler_console::console_state *
|
fhandler_console::console_state *
|
||||||
fhandler_console::open_shared_console (HWND hw, HANDLE& h, bool& create)
|
fhandler_console::open_shared_console (HWND hw, HANDLE& h, bool& created)
|
||||||
{
|
{
|
||||||
wchar_t namebuf[(sizeof "XXXXXXXXXXXXXXXXXX-consNNNNNNNNNN")];
|
wchar_t namebuf[(sizeof "XXXXXXXXXXXXXXXXXX-consNNNNNNNNNN")];
|
||||||
__small_swprintf (namebuf, L"%S-cons%p", &cygheap->installation_key, hw);
|
__small_swprintf (namebuf, L"%S-cons%p", &cygheap->installation_key, hw);
|
||||||
|
|
||||||
shared_locations m = create ? SH_SHARED_CONSOLE : SH_JUSTOPEN;
|
shared_locations m = created ? SH_SHARED_CONSOLE : SH_JUSTOPEN;
|
||||||
console_state *res = (console_state *)
|
console_state *res = (console_state *)
|
||||||
open_shared (namebuf, 0, h, sizeof (console_state), &m);
|
open_shared (namebuf, 0, h, sizeof (console_state), m, created);
|
||||||
create = m != SH_JUSTOPEN;
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -89,9 +89,9 @@ HANDLE get_session_parent_dir ();
|
||||||
char *shared_name (char *, const char *, int);
|
char *shared_name (char *, const char *, int);
|
||||||
WCHAR *shared_name (WCHAR *, const WCHAR *, int);
|
WCHAR *shared_name (WCHAR *, const WCHAR *, int);
|
||||||
void *open_shared (const WCHAR *, int, HANDLE&, DWORD,
|
void *open_shared (const WCHAR *, int, HANDLE&, DWORD,
|
||||||
shared_locations, PSECURITY_ATTRIBUTES = &sec_all,
|
shared_locations, PSECURITY_ATTRIBUTES = &sec_all,
|
||||||
DWORD = FILE_MAP_READ | FILE_MAP_WRITE);
|
DWORD = FILE_MAP_READ | FILE_MAP_WRITE);
|
||||||
void *open_shared (const WCHAR *, int, HANDLE&, DWORD,
|
void *open_shared (const WCHAR *, int, HANDLE&, DWORD,
|
||||||
shared_locations *, PSECURITY_ATTRIBUTES = &sec_all,
|
shared_locations, bool &, PSECURITY_ATTRIBUTES = &sec_all,
|
||||||
DWORD = FILE_MAP_READ | FILE_MAP_WRITE);
|
DWORD = FILE_MAP_READ | FILE_MAP_WRITE);
|
||||||
extern void user_shared_create (bool reinit);
|
extern void user_shared_create (bool reinit);
|
||||||
|
|
|
@ -127,54 +127,57 @@ void *
|
||||||
open_shared (const WCHAR *name, int n, HANDLE& shared_h, DWORD size,
|
open_shared (const WCHAR *name, int n, HANDLE& shared_h, DWORD size,
|
||||||
shared_locations m, PSECURITY_ATTRIBUTES psa, DWORD access)
|
shared_locations m, PSECURITY_ATTRIBUTES psa, DWORD access)
|
||||||
{
|
{
|
||||||
return open_shared (name, n, shared_h, size, &m, psa, access);
|
bool created_dummy;
|
||||||
|
return open_shared (name, n, shared_h, size, m, created_dummy, psa, access);
|
||||||
}
|
}
|
||||||
|
|
||||||
void *
|
void *
|
||||||
open_shared (const WCHAR *name, int n, HANDLE& shared_h, DWORD size,
|
open_shared (const WCHAR *name, int n, HANDLE& shared_h, DWORD size,
|
||||||
shared_locations *m, PSECURITY_ATTRIBUTES psa, DWORD access)
|
shared_locations m, bool &created, PSECURITY_ATTRIBUTES psa,
|
||||||
|
DWORD access)
|
||||||
{
|
{
|
||||||
void *shared;
|
|
||||||
|
|
||||||
void *addr;
|
|
||||||
if (*m == SH_JUSTCREATE || *m == SH_JUSTOPEN)
|
|
||||||
addr = NULL;
|
|
||||||
else
|
|
||||||
addr = (void *) region_address[*m];
|
|
||||||
|
|
||||||
WCHAR map_buf[MAX_PATH];
|
WCHAR map_buf[MAX_PATH];
|
||||||
WCHAR *mapname = NULL;
|
WCHAR *mapname = NULL;
|
||||||
|
void *shared;
|
||||||
|
void *addr;
|
||||||
|
|
||||||
if (shared_h)
|
if (m == SH_JUSTCREATE || m == SH_JUSTOPEN)
|
||||||
*m = SH_JUSTOPEN;
|
addr = NULL;
|
||||||
else
|
else
|
||||||
|
addr = (void *) region_address[m];
|
||||||
|
|
||||||
|
created = false;
|
||||||
|
if (!shared_h)
|
||||||
{
|
{
|
||||||
if (name)
|
if (name)
|
||||||
mapname = shared_name (map_buf, name, n);
|
mapname = shared_name (map_buf, name, n);
|
||||||
if (*m == SH_JUSTOPEN)
|
if (m == SH_JUSTOPEN)
|
||||||
shared_h = OpenFileMappingW (access, FALSE, mapname);
|
shared_h = OpenFileMappingW (FILE_MAP_READ | FILE_MAP_WRITE, FALSE,
|
||||||
|
mapname);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
created = true;
|
||||||
shared_h = CreateFileMappingW (INVALID_HANDLE_VALUE, psa,
|
shared_h = CreateFileMappingW (INVALID_HANDLE_VALUE, psa,
|
||||||
PAGE_READWRITE, 0, size, mapname);
|
PAGE_READWRITE, 0, size, mapname);
|
||||||
if (GetLastError () == ERROR_ALREADY_EXISTS)
|
if (GetLastError () == ERROR_ALREADY_EXISTS)
|
||||||
*m = SH_JUSTOPEN;
|
created = false;
|
||||||
}
|
}
|
||||||
if (shared_h)
|
if (shared_h)
|
||||||
/* ok! */;
|
/* ok! */;
|
||||||
else if (*m != SH_JUSTOPEN)
|
else if (m != SH_JUSTOPEN)
|
||||||
api_fatal ("CreateFileMapping %W, %E. Terminating.", mapname);
|
api_fatal ("CreateFileMapping %W, %E. Terminating.", mapname);
|
||||||
else
|
else
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
shared = (shared_info *) MapViewOfFileEx (shared_h, access, 0, 0, 0, addr);
|
shared = MapViewOfFileEx (shared_h, FILE_MAP_READ | FILE_MAP_WRITE,
|
||||||
|
0, 0, 0, addr);
|
||||||
|
|
||||||
if (!shared)
|
if (!shared)
|
||||||
api_fatal ("MapViewOfFileEx '%W'(%p), %E. Terminating.", mapname, shared_h);
|
api_fatal ("MapViewOfFileEx '%W'(%p), %E. Terminating.", mapname, shared_h);
|
||||||
|
|
||||||
debug_printf ("name %W, n %d, shared %p (wanted %p), h %p, *m %d",
|
debug_printf ("name %W, n %d, shared %p (wanted %p), h %p, m %d",
|
||||||
mapname, n, shared, addr, shared_h, *m);
|
mapname, n, shared, addr, shared_h, m);
|
||||||
|
|
||||||
return shared;
|
return shared;
|
||||||
}
|
}
|
||||||
|
|
|
@ -387,8 +387,10 @@ pinfo::init (pid_t n, DWORD flag, HANDLE h0)
|
||||||
|
|
||||||
for (int i = 0; i < 20; i++)
|
for (int i = 0; i < 20; i++)
|
||||||
{
|
{
|
||||||
|
bool created;
|
||||||
|
|
||||||
procinfo = (_pinfo *) open_shared (L"cygpid", n, h0, sizeof (_pinfo),
|
procinfo = (_pinfo *) open_shared (L"cygpid", n, h0, sizeof (_pinfo),
|
||||||
&shloc, sec_attribs, access);
|
shloc, created, sec_attribs, access);
|
||||||
if (!h0)
|
if (!h0)
|
||||||
{
|
{
|
||||||
if (createit)
|
if (createit)
|
||||||
|
@ -409,8 +411,6 @@ pinfo::init (pid_t n, DWORD flag, HANDLE h0)
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool created = shloc != SH_JUSTOPEN;
|
|
||||||
|
|
||||||
/* Just fetching info for ps or /proc, don't do anything rash. */
|
/* Just fetching info for ps or /proc, don't do anything rash. */
|
||||||
if (!created && !(flag & PID_NEW) && !procinfo->ppid
|
if (!created && !(flag & PID_NEW) && !procinfo->ppid
|
||||||
&& (flag & PID_PROCINFO))
|
&& (flag & PID_PROCINFO))
|
||||||
|
|
Loading…
Reference in New Issue