Commit b8a10943 by Christoph von Wittich Committed by Danny Smith

PR/other 30335

2007-07-19  Christoph von Wittich  <Christoph_vW@reactos.org>
	    Danny Smith  <dannysmith@users.sourceforge.net>

	PR/other 30335
	* config/i386/host-mingw32.c (mingw32_gt_pch_use_address): Put
	file mapping object in local namespace if Windows version later
	than NT4


Co-Authored-By: Danny Smith <dannysmith@users.sourceforge.net>

From-SVN: r126719
parent 8426b956
2007-07-19 Christoph von Wittich <Christoph_vW@reactos.org>
Danny Smith <dannysmith@users.sourceforge.net>
PR/other 30335
* config/i386/host-mingw32.c (mingw32_gt_pch_use_address): Put
file mapping object in local namespace if Windows version later
than NT4
2007-07-18 Richard Sandiford <richard@codesourcery.com> 2007-07-18 Richard Sandiford <richard@codesourcery.com>
* config/arm/arm-protos.h (arm_cannot_force_const_mem): Declare. * config/arm/arm-protos.h (arm_cannot_force_const_mem): Declare.
......
/* mingw32 host-specific hook definitions. /* mingw32 host-specific hook definitions.
Copyright (C) 2004 Free Software Foundation, Inc. Copyright (C) 2004, 2007 Free Software Foundation, Inc.
This file is part of GCC. This file is part of GCC.
...@@ -87,11 +87,11 @@ mingw32_gt_pch_get_address (size_t size, int fd ATTRIBUTE_UNUSED) ...@@ -87,11 +87,11 @@ mingw32_gt_pch_get_address (size_t size, int fd ATTRIBUTE_UNUSED)
/* FIXME: We let system determine base by setting first arg to NULL. /* FIXME: We let system determine base by setting first arg to NULL.
Allocating at top of available address space avoids unnecessary Allocating at top of available address space avoids unnecessary
fragmentation of "ordinary" (malloc's) address space but may not be safe fragmentation of "ordinary" (malloc's) address space but may not
with delayed load of system dll's. Preferred addresses for NT system be safe with delayed load of system dll's. Preferred addresses
dlls is in 0x70000000 to 0x78000000 range. for NT system dlls is in 0x70000000 to 0x78000000 range.
If we allocate at bottom we need to reserve the address as early as possible If we allocate at bottom we need to reserve the address as early
and at the same point in each invocation. */ as possible and at the same point in each invocation. */
res = VirtualAlloc (NULL, pch_VA_max_size, res = VirtualAlloc (NULL, pch_VA_max_size,
MEM_RESERVE | MEM_TOP_DOWN, MEM_RESERVE | MEM_TOP_DOWN,
...@@ -115,19 +115,36 @@ mingw32_gt_pch_use_address (void *addr, size_t size, int fd, ...@@ -115,19 +115,36 @@ mingw32_gt_pch_use_address (void *addr, size_t size, int fd,
size_t offset) size_t offset)
{ {
void * mmap_addr; void * mmap_addr;
static HANDLE mmap_handle; HANDLE mmap_handle;
if (size == 0) /* Apparently, MS Vista puts unnamed file mapping objects into Global
return 0; namespace when running an application in a Terminal Server
session. This causes failure since, by default, applications
don't get SeCreateGlobalPrivilege. We don't need global
memory sharing so explicitly put object into Local namespace. */
const char object_name[] = "Local\\MinGWGCCPCH";
/* However, the documentation for CreateFileMapping says that on NT4
and earlier, backslashes are invalid in object name. So, we need
to check if we are on Windows2000 or higher. */
OSVERSIONINFO version_info;
if (size == 0)
return 0;
/* Offset must be also be a multiple of allocation granularity for /* Offset must be also be a multiple of allocation granularity for
this to work. We can't change the offset. */ this to work. We can't change the offset. */
if ((offset & (va_granularity - 1)) != 0 || size > pch_VA_max_size) if ((offset & (va_granularity - 1)) != 0 || size > pch_VA_max_size)
return -1; return -1;
mmap_handle = CreateFileMapping ((HANDLE) _get_osfhandle (fd), /* Determine the version of Windows we are running on. */
NULL, PAGE_WRITECOPY | SEC_COMMIT, version_info.dwOSVersionInfoSize = sizeof (version_info);
0, 0, NULL); GetVersionEx (&version_info);
mmap_handle = CreateFileMappingA ((HANDLE) _get_osfhandle (fd), NULL,
PAGE_WRITECOPY | SEC_COMMIT, 0, 0,
version_info.dwMajorVersion > 4
? object_name : NULL);
if (mmap_handle == NULL) if (mmap_handle == NULL)
{ {
w32_error (__FUNCTION__, __FILE__, __LINE__, "CreateFileMapping"); w32_error (__FUNCTION__, __FILE__, __LINE__, "CreateFileMapping");
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment