Add Wine-internal allocation type MEM_SYSTEM for VirtualAlloc to
register external mappings (like video frame buffers).
diff --git a/include/winbase.h b/include/winbase.h
index 2612453..2c2a0de 100644
--- a/include/winbase.h
+++ b/include/winbase.h
@@ -909,6 +909,9 @@
#define MEM_PRIVATE 0x00020000
#define MEM_MAPPED 0x00040000
#define MEM_TOP_DOWN 0x00100000
+#ifdef __WINE__
+#define MEM_SYSTEM 0x80000000
+#endif
#define SEC_FILE 0x00800000
#define SEC_IMAGE 0x01000000
diff --git a/memory/virtual.c b/memory/virtual.c
index 9571842..edd1ea8 100644
--- a/memory/virtual.c
+++ b/memory/virtual.c
@@ -256,7 +256,8 @@
static void VIRTUAL_DeleteView(
FILE_VIEW *view /* [in] View */
) {
- FILE_munmap( (void *)view->base, 0, view->size );
+ if (!(view->flags & VFLAG_SYSTEM))
+ FILE_munmap( (void *)view->base, 0, view->size );
if (view->next) view->next->prev = view->prev;
if (view->prev) view->prev->next = view->next;
else VIRTUAL_FirstView = view->next;
@@ -598,13 +599,13 @@
}
/* Compute the protection flags */
- if (!(type & (MEM_COMMIT | MEM_RESERVE)) ||
- (type & ~(MEM_COMMIT | MEM_RESERVE)))
+ if (!(type & (MEM_COMMIT | MEM_RESERVE | MEM_SYSTEM)) ||
+ (type & ~(MEM_COMMIT | MEM_RESERVE | MEM_SYSTEM)))
{
SetLastError( ERROR_INVALID_PARAMETER );
return NULL;
}
- if (type & MEM_COMMIT)
+ if (type & (MEM_COMMIT | MEM_SYSTEM))
vprot = VIRTUAL_GetProt( protect ) | VPROT_COMMITTED;
else vprot = 0;
@@ -613,8 +614,11 @@
if ((type & MEM_RESERVE) || !base)
{
view_size = size + (base ? 0 : granularity_mask + 1);
- ptr = (UINT)FILE_dommap( -1, (LPVOID)base, 0, view_size, 0, 0,
- VIRTUAL_GetUnixProt( vprot ), MAP_PRIVATE );
+ if (type & MEM_SYSTEM)
+ ptr = base;
+ else
+ ptr = (UINT)FILE_dommap( -1, (LPVOID)base, 0, view_size, 0, 0,
+ VIRTUAL_GetUnixProt( vprot ), MAP_PRIVATE );
if (ptr == (UINT)-1)
{
SetLastError( ERROR_OUTOFMEMORY );
@@ -642,7 +646,8 @@
SetLastError( ERROR_INVALID_ADDRESS );
return NULL;
}
- if (!(view = VIRTUAL_CreateView( ptr, size, 0, 0, vprot, -1 )))
+ if (!(view = VIRTUAL_CreateView( ptr, size, 0, (type & MEM_SYSTEM) ?
+ VFLAG_SYSTEM : 0, vprot, -1 )))
{
FILE_munmap( (void *)ptr, 0, size );
SetLastError( ERROR_OUTOFMEMORY );