Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
10a8b2cd
Commit
10a8b2cd
authored
Jan 15, 2014
by
Stefan Dösinger
Committed by
Alexandre Julliard
Jan 16, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wined3d: Remove resource->allocatedMemory.
parent
abb620ed
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
25 additions
and
30 deletions
+25
-30
buffer.c
dlls/wined3d/buffer.c
+23
-26
drawprim.c
dlls/wined3d/drawprim.c
+1
-1
resource.c
dlls/wined3d/resource.c
+0
-2
wined3d_private.h
dlls/wined3d/wined3d_private.h
+1
-1
No files found.
dlls/wined3d/buffer.c
View file @
10a8b2cd
...
@@ -3,7 +3,7 @@
...
@@ -3,7 +3,7 @@
* Copyright 2002-2005 Raphael Junqueira
* Copyright 2002-2005 Raphael Junqueira
* Copyright 2004 Christian Costa
* Copyright 2004 Christian Costa
* Copyright 2005 Oliver Stieber
* Copyright 2005 Oliver Stieber
* Copyright 2007-2011, 2013 Stefan Dösinger for CodeWeavers
* Copyright 2007-2011, 2013
-2014
Stefan Dösinger for CodeWeavers
* Copyright 2009-2010 Henri Verbeet for CodeWeavers
* Copyright 2009-2010 Henri Verbeet for CodeWeavers
*
*
* This library is free software; you can redistribute it and/or
* This library is free software; you can redistribute it and/or
...
@@ -181,7 +181,7 @@ static void buffer_create_buffer_object(struct wined3d_buffer *This, struct wine
...
@@ -181,7 +181,7 @@ static void buffer_create_buffer_object(struct wined3d_buffer *This, struct wine
* calling glBufferSubData on updates. Upload the actual data in case
* calling glBufferSubData on updates. Upload the actual data in case
* we're not double buffering, so we can release the heap mem afterwards
* we're not double buffering, so we can release the heap mem afterwards
*/
*/
GL_EXTCALL
(
glBufferDataARB
(
This
->
buffer_type_hint
,
This
->
resource
.
size
,
This
->
resource
.
allocatedM
emory
,
gl_usage
));
GL_EXTCALL
(
glBufferDataARB
(
This
->
buffer_type_hint
,
This
->
resource
.
size
,
This
->
resource
.
heap_m
emory
,
gl_usage
));
error
=
gl_info
->
gl_ops
.
gl
.
p_glGetError
();
error
=
gl_info
->
gl_ops
.
gl
.
p_glGetError
();
if
(
error
!=
GL_NO_ERROR
)
if
(
error
!=
GL_NO_ERROR
)
{
{
...
@@ -192,14 +192,9 @@ static void buffer_create_buffer_object(struct wined3d_buffer *This, struct wine
...
@@ -192,14 +192,9 @@ static void buffer_create_buffer_object(struct wined3d_buffer *This, struct wine
This
->
buffer_object_usage
=
gl_usage
;
This
->
buffer_object_usage
=
gl_usage
;
if
(
This
->
flags
&
WINED3D_BUFFER_DOUBLEBUFFER
)
if
(
This
->
flags
&
WINED3D_BUFFER_DOUBLEBUFFER
)
{
buffer_invalidate_bo_range
(
This
,
0
,
0
);
buffer_invalidate_bo_range
(
This
,
0
,
0
);
}
else
else
{
wined3d_resource_free_sysmem
(
&
This
->
resource
);
wined3d_resource_free_sysmem
(
&
This
->
resource
);
This
->
resource
.
allocatedMemory
=
NULL
;
}
return
;
return
;
...
@@ -473,7 +468,7 @@ void buffer_get_memory(struct wined3d_buffer *buffer, struct wined3d_context *co
...
@@ -473,7 +468,7 @@ void buffer_get_memory(struct wined3d_buffer *buffer, struct wined3d_context *co
return
;
return
;
}
}
}
}
data
->
addr
=
buffer
->
resource
.
allocatedM
emory
;
data
->
addr
=
buffer
->
resource
.
heap_m
emory
;
}
}
else
else
{
{
...
@@ -495,21 +490,21 @@ BYTE *buffer_get_sysmem(struct wined3d_buffer *This, struct wined3d_context *con
...
@@ -495,21 +490,21 @@ BYTE *buffer_get_sysmem(struct wined3d_buffer *This, struct wined3d_context *con
{
{
const
struct
wined3d_gl_info
*
gl_info
=
context
->
gl_info
;
const
struct
wined3d_gl_info
*
gl_info
=
context
->
gl_info
;
/* AllocatedMemory exists if the buffer is double buffered or has no buffer object at all */
/* Heap_memory exists if the buffer is double buffered or has no buffer object at all. */
if
(
This
->
resource
.
allocatedMemory
)
return
This
->
resource
.
allocatedMemory
;
if
(
This
->
resource
.
heap_memory
)
return
This
->
resource
.
heap_memory
;
if
(
!
wined3d_resource_allocate_sysmem
(
&
This
->
resource
))
if
(
!
wined3d_resource_allocate_sysmem
(
&
This
->
resource
))
ERR
(
"Failed to allocate system memory.
\n
"
);
ERR
(
"Failed to allocate system memory.
\n
"
);
This
->
resource
.
allocatedMemory
=
This
->
resource
.
heap_memory
;
if
(
This
->
buffer_type_hint
==
GL_ELEMENT_ARRAY_BUFFER_ARB
)
if
(
This
->
buffer_type_hint
==
GL_ELEMENT_ARRAY_BUFFER_ARB
)
context_invalidate_state
(
context
,
STATE_INDEXBUFFER
);
context_invalidate_state
(
context
,
STATE_INDEXBUFFER
);
GL_EXTCALL
(
glBindBufferARB
(
This
->
buffer_type_hint
,
This
->
buffer_object
));
GL_EXTCALL
(
glBindBufferARB
(
This
->
buffer_type_hint
,
This
->
buffer_object
));
GL_EXTCALL
(
glGetBufferSubDataARB
(
This
->
buffer_type_hint
,
0
,
This
->
resource
.
size
,
This
->
resource
.
allocatedM
emory
));
GL_EXTCALL
(
glGetBufferSubDataARB
(
This
->
buffer_type_hint
,
0
,
This
->
resource
.
size
,
This
->
resource
.
heap_m
emory
));
This
->
flags
|=
WINED3D_BUFFER_DOUBLEBUFFER
;
This
->
flags
|=
WINED3D_BUFFER_DOUBLEBUFFER
;
return
This
->
resource
.
allocatedM
emory
;
return
This
->
resource
.
heap_m
emory
;
}
}
static
void
buffer_unload
(
struct
wined3d_resource
*
resource
)
static
void
buffer_unload
(
struct
wined3d_resource
*
resource
)
...
@@ -709,7 +704,7 @@ static void buffer_direct_upload(struct wined3d_buffer *This, const struct wined
...
@@ -709,7 +704,7 @@ static void buffer_direct_upload(struct wined3d_buffer *This, const struct wined
start
=
This
->
maps
[
This
->
modified_areas
].
offset
;
start
=
This
->
maps
[
This
->
modified_areas
].
offset
;
len
=
This
->
maps
[
This
->
modified_areas
].
size
;
len
=
This
->
maps
[
This
->
modified_areas
].
size
;
memcpy
(
map
+
start
,
This
->
resource
.
allocatedM
emory
+
start
,
len
);
memcpy
(
map
+
start
,
(
BYTE
*
)
This
->
resource
.
heap_m
emory
+
start
,
len
);
if
(
gl_info
->
supported
[
ARB_MAP_BUFFER_RANGE
])
if
(
gl_info
->
supported
[
ARB_MAP_BUFFER_RANGE
])
{
{
...
@@ -861,7 +856,7 @@ void buffer_internal_preload(struct wined3d_buffer *buffer, struct wined3d_conte
...
@@ -861,7 +856,7 @@ void buffer_internal_preload(struct wined3d_buffer *buffer, struct wined3d_conte
if
(
!
buffer
->
conversion_map
)
if
(
!
buffer
->
conversion_map
)
{
{
/* That means that there is nothing to fixup. Just upload from
/* That means that there is nothing to fixup. Just upload from
* buffer->resource.
allocatedM
emory directly into the vbo. Do not
* buffer->resource.
heap_m
emory directly into the vbo. Do not
* free the system memory copy because drawPrimitive may need it if
* free the system memory copy because drawPrimitive may need it if
* the stride is 0, for instancing emulation, vertex blending
* the stride is 0, for instancing emulation, vertex blending
* emulation or shader emulation. */
* emulation or shader emulation. */
...
@@ -897,7 +892,7 @@ void buffer_internal_preload(struct wined3d_buffer *buffer, struct wined3d_conte
...
@@ -897,7 +892,7 @@ void buffer_internal_preload(struct wined3d_buffer *buffer, struct wined3d_conte
len
=
buffer
->
maps
[
buffer
->
modified_areas
].
size
;
len
=
buffer
->
maps
[
buffer
->
modified_areas
].
size
;
end
=
start
+
len
;
end
=
start
+
len
;
memcpy
(
data
+
start
,
buffer
->
resource
.
allocatedM
emory
+
start
,
end
-
start
);
memcpy
(
data
+
start
,
(
BYTE
*
)
buffer
->
resource
.
heap_m
emory
+
start
,
end
-
start
);
for
(
i
=
start
/
buffer
->
stride
;
i
<
min
((
end
/
buffer
->
stride
)
+
1
,
vertices
);
++
i
)
for
(
i
=
start
/
buffer
->
stride
;
i
<
min
((
end
/
buffer
->
stride
)
+
1
,
vertices
);
++
i
)
{
{
for
(
j
=
0
;
j
<
buffer
->
stride
;
++
j
)
for
(
j
=
0
;
j
<
buffer
->
stride
;
++
j
)
...
@@ -951,6 +946,7 @@ HRESULT CDECL wined3d_buffer_map(struct wined3d_buffer *buffer, UINT offset, UIN
...
@@ -951,6 +946,7 @@ HRESULT CDECL wined3d_buffer_map(struct wined3d_buffer *buffer, UINT offset, UIN
{
{
BOOL
dirty
=
buffer_is_dirty
(
buffer
);
BOOL
dirty
=
buffer_is_dirty
(
buffer
);
LONG
count
;
LONG
count
;
BYTE
*
base
;
TRACE
(
"buffer %p, offset %u, size %u, data %p, flags %#x
\n
"
,
buffer
,
offset
,
size
,
data
,
flags
);
TRACE
(
"buffer %p, offset %u, size %u, data %p, flags %#x
\n
"
,
buffer
,
offset
,
size
,
data
,
flags
);
...
@@ -986,7 +982,7 @@ HRESULT CDECL wined3d_buffer_map(struct wined3d_buffer *buffer, UINT offset, UIN
...
@@ -986,7 +982,7 @@ HRESULT CDECL wined3d_buffer_map(struct wined3d_buffer *buffer, UINT offset, UIN
if
(
gl_info
->
supported
[
ARB_MAP_BUFFER_RANGE
])
if
(
gl_info
->
supported
[
ARB_MAP_BUFFER_RANGE
])
{
{
GLbitfield
mapflags
=
wined3d_resource_gl_map_flags
(
flags
);
GLbitfield
mapflags
=
wined3d_resource_gl_map_flags
(
flags
);
buffer
->
resource
.
allocatedMemory
=
GL_EXTCALL
(
glMapBufferRange
(
buffer
->
buffer_type_hint
,
buffer
->
map_ptr
=
GL_EXTCALL
(
glMapBufferRange
(
buffer
->
buffer_type_hint
,
0
,
buffer
->
resource
.
size
,
mapflags
));
0
,
buffer
->
resource
.
size
,
mapflags
));
checkGLcall
(
"glMapBufferRange"
);
checkGLcall
(
"glMapBufferRange"
);
}
}
...
@@ -994,18 +990,18 @@ HRESULT CDECL wined3d_buffer_map(struct wined3d_buffer *buffer, UINT offset, UIN
...
@@ -994,18 +990,18 @@ HRESULT CDECL wined3d_buffer_map(struct wined3d_buffer *buffer, UINT offset, UIN
{
{
if
(
buffer
->
flags
&
WINED3D_BUFFER_APPLESYNC
)
if
(
buffer
->
flags
&
WINED3D_BUFFER_APPLESYNC
)
buffer_sync_apple
(
buffer
,
flags
,
gl_info
);
buffer_sync_apple
(
buffer
,
flags
,
gl_info
);
buffer
->
resource
.
allocatedMemory
=
GL_EXTCALL
(
glMapBufferARB
(
buffer
->
buffer_type_hint
,
buffer
->
map_ptr
=
GL_EXTCALL
(
glMapBufferARB
(
buffer
->
buffer_type_hint
,
GL_READ_WRITE_ARB
));
GL_READ_WRITE_ARB
));
checkGLcall
(
"glMapBufferARB"
);
checkGLcall
(
"glMapBufferARB"
);
}
}
if
(((
DWORD_PTR
)
buffer
->
resource
.
allocatedMemory
)
&
(
RESOURCE_ALIGNMENT
-
1
))
if
(((
DWORD_PTR
)
buffer
->
map_ptr
)
&
(
RESOURCE_ALIGNMENT
-
1
))
{
{
WARN
(
"Pointer %p is not %u byte aligned.
\n
"
,
buffer
->
resource
.
allocatedMemory
,
RESOURCE_ALIGNMENT
);
WARN
(
"Pointer %p is not %u byte aligned.
\n
"
,
buffer
->
map_ptr
,
RESOURCE_ALIGNMENT
);
GL_EXTCALL
(
glUnmapBufferARB
(
buffer
->
buffer_type_hint
));
GL_EXTCALL
(
glUnmapBufferARB
(
buffer
->
buffer_type_hint
));
checkGLcall
(
"glUnmapBufferARB"
);
checkGLcall
(
"glUnmapBufferARB"
);
buffer
->
resource
.
allocatedMemory
=
NULL
;
buffer
->
map_ptr
=
NULL
;
if
(
buffer
->
resource
.
usage
&
WINED3DUSAGE_DYNAMIC
)
if
(
buffer
->
resource
.
usage
&
WINED3DUSAGE_DYNAMIC
)
{
{
...
@@ -1024,7 +1020,8 @@ HRESULT CDECL wined3d_buffer_map(struct wined3d_buffer *buffer, UINT offset, UIN
...
@@ -1024,7 +1020,8 @@ HRESULT CDECL wined3d_buffer_map(struct wined3d_buffer *buffer, UINT offset, UIN
TRACE
(
"Falling back to doublebuffered operation
\n
"
);
TRACE
(
"Falling back to doublebuffered operation
\n
"
);
buffer_get_sysmem
(
buffer
,
context
);
buffer_get_sysmem
(
buffer
,
context
);
}
}
TRACE
(
"New pointer is %p.
\n
"
,
buffer
->
resource
.
allocatedMemory
);
TRACE
(
"New pointer is %p.
\n
"
,
buffer
->
resource
.
heap_memory
);
buffer
->
map_ptr
=
NULL
;
}
}
context_release
(
context
);
context_release
(
context
);
}
}
...
@@ -1050,9 +1047,10 @@ HRESULT CDECL wined3d_buffer_map(struct wined3d_buffer *buffer, UINT offset, UIN
...
@@ -1050,9 +1047,10 @@ HRESULT CDECL wined3d_buffer_map(struct wined3d_buffer *buffer, UINT offset, UIN
}
}
}
}
*
data
=
buffer
->
resource
.
allocatedMemory
+
offset
;
base
=
buffer
->
map_ptr
?
buffer
->
map_ptr
:
buffer
->
resource
.
heap_memory
;
*
data
=
base
+
offset
;
TRACE
(
"Returning memory at %p (base %p, offset %u).
\n
"
,
*
data
,
b
uffer
->
resource
.
allocatedMemory
,
offset
);
TRACE
(
"Returning memory at %p (base %p, offset %u).
\n
"
,
*
data
,
b
ase
,
offset
);
/* TODO: check Flags compatibility with buffer->currentDesc.Usage (see MSDN) */
/* TODO: check Flags compatibility with buffer->currentDesc.Usage (see MSDN) */
return
WINED3D_OK
;
return
WINED3D_OK
;
...
@@ -1118,7 +1116,6 @@ void CDECL wined3d_buffer_unmap(struct wined3d_buffer *buffer)
...
@@ -1118,7 +1116,6 @@ void CDECL wined3d_buffer_unmap(struct wined3d_buffer *buffer)
gl_info
->
gl_ops
.
gl
.
p_glFlush
();
/* Flush to ensure ordering across contexts. */
gl_info
->
gl_ops
.
gl
.
p_glFlush
();
/* Flush to ensure ordering across contexts. */
context_release
(
context
);
context_release
(
context
);
buffer
->
resource
.
allocatedMemory
=
NULL
;
buffer_clear_dirty_areas
(
buffer
);
buffer_clear_dirty_areas
(
buffer
);
}
}
else
if
(
buffer
->
flags
&
WINED3D_BUFFER_HASDESC
)
else
if
(
buffer
->
flags
&
WINED3D_BUFFER_HASDESC
)
...
@@ -1158,7 +1155,7 @@ static HRESULT buffer_init(struct wined3d_buffer *buffer, struct wined3d_device
...
@@ -1158,7 +1155,7 @@ static HRESULT buffer_init(struct wined3d_buffer *buffer, struct wined3d_device
buffer
->
buffer_type_hint
=
bind_hint
;
buffer
->
buffer_type_hint
=
bind_hint
;
TRACE
(
"size %#x, usage %#x, format %s, memory @ %p, iface @ %p.
\n
"
,
buffer
->
resource
.
size
,
buffer
->
resource
.
usage
,
TRACE
(
"size %#x, usage %#x, format %s, memory @ %p, iface @ %p.
\n
"
,
buffer
->
resource
.
size
,
buffer
->
resource
.
usage
,
debug_d3dformat
(
buffer
->
resource
.
format
->
id
),
buffer
->
resource
.
allocatedM
emory
,
buffer
);
debug_d3dformat
(
buffer
->
resource
.
format
->
id
),
buffer
->
resource
.
heap_m
emory
,
buffer
);
if
(
device
->
create_parms
.
flags
&
WINED3DCREATE_SOFTWARE_VERTEXPROCESSING
)
if
(
device
->
create_parms
.
flags
&
WINED3DCREATE_SOFTWARE_VERTEXPROCESSING
)
{
{
...
...
dlls/wined3d/drawprim.c
View file @
10a8b2cd
...
@@ -692,7 +692,7 @@ void draw_primitive(struct wined3d_device *device, UINT start_idx, UINT index_co
...
@@ -692,7 +692,7 @@ void draw_primitive(struct wined3d_device *device, UINT start_idx, UINT index_co
{
{
struct
wined3d_buffer
*
index_buffer
=
state
->
index_buffer
;
struct
wined3d_buffer
*
index_buffer
=
state
->
index_buffer
;
if
(
!
index_buffer
->
buffer_object
||
!
stream_info
->
all_vbo
)
if
(
!
index_buffer
->
buffer_object
||
!
stream_info
->
all_vbo
)
idx_data
=
index_buffer
->
resource
.
allocatedM
emory
;
idx_data
=
index_buffer
->
resource
.
heap_m
emory
;
else
else
{
{
ib_query
=
index_buffer
->
query
;
ib_query
=
index_buffer
->
query
;
...
...
dlls/wined3d/resource.c
View file @
10a8b2cd
...
@@ -130,7 +130,6 @@ HRESULT resource_init(struct wined3d_resource *resource, struct wined3d_device *
...
@@ -130,7 +130,6 @@ HRESULT resource_init(struct wined3d_resource *resource, struct wined3d_device *
{
{
resource
->
heap_memory
=
NULL
;
resource
->
heap_memory
=
NULL
;
}
}
resource
->
allocatedMemory
=
resource
->
heap_memory
;
/* Check that we have enough video ram left */
/* Check that we have enough video ram left */
if
(
pool
==
WINED3D_POOL_DEFAULT
&&
d3d
->
flags
&
WINED3D_VIDMEM_ACCOUNTING
)
if
(
pool
==
WINED3D_POOL_DEFAULT
&&
d3d
->
flags
&
WINED3D_VIDMEM_ACCOUNTING
)
...
@@ -173,7 +172,6 @@ void resource_cleanup(struct wined3d_resource *resource)
...
@@ -173,7 +172,6 @@ void resource_cleanup(struct wined3d_resource *resource)
}
}
wined3d_resource_free_sysmem
(
resource
);
wined3d_resource_free_sysmem
(
resource
);
resource
->
allocatedMemory
=
NULL
;
device_resource_released
(
resource
->
device
,
resource
);
device_resource_released
(
resource
->
device
,
resource
);
}
}
...
...
dlls/wined3d/wined3d_private.h
View file @
10a8b2cd
...
@@ -1999,7 +1999,6 @@ struct wined3d_resource
...
@@ -1999,7 +1999,6 @@ struct wined3d_resource
UINT
depth
;
UINT
depth
;
UINT
size
;
UINT
size
;
DWORD
priority
;
DWORD
priority
;
BYTE
*
allocatedMemory
;
/* Pointer to the real data location */
void
*
heap_memory
;
void
*
heap_memory
;
struct
list
privateData
;
struct
list
privateData
;
struct
list
resource_list_entry
;
struct
list
resource_list_entry
;
...
@@ -2559,6 +2558,7 @@ struct wined3d_buffer
...
@@ -2559,6 +2558,7 @@ struct wined3d_buffer
GLenum
buffer_object_usage
;
GLenum
buffer_object_usage
;
GLenum
buffer_type_hint
;
GLenum
buffer_type_hint
;
DWORD
flags
;
DWORD
flags
;
void
*
map_ptr
;
struct
wined3d_map_range
*
maps
;
struct
wined3d_map_range
*
maps
;
ULONG
maps_size
,
modified_areas
;
ULONG
maps_size
,
modified_areas
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment