Commit 5e64fd70 authored by Henri Verbeet's avatar Henri Verbeet Committed by Alexandre Julliard

wined3d: Don't bother downloading buffer contents on destruction.

parent 6c45e6fe
...@@ -551,12 +551,21 @@ static void buffer_unload(struct wined3d_resource *resource) ...@@ -551,12 +551,21 @@ static void buffer_unload(struct wined3d_resource *resource)
ULONG CDECL wined3d_buffer_decref(struct wined3d_buffer *buffer) ULONG CDECL wined3d_buffer_decref(struct wined3d_buffer *buffer)
{ {
ULONG refcount = InterlockedDecrement(&buffer->resource.ref); ULONG refcount = InterlockedDecrement(&buffer->resource.ref);
struct wined3d_context *context;
TRACE("%p decreasing refcount to %u.\n", buffer, refcount); TRACE("%p decreasing refcount to %u.\n", buffer, refcount);
if (!refcount) if (!refcount)
{ {
buffer_unload(&buffer->resource); if (buffer->buffer_object)
{
context = context_acquire(buffer->resource.device, NULL);
delete_gl_buffer(buffer, context->gl_info);
context_release(context);
HeapFree(GetProcessHeap(), 0, buffer->conversion_map);
}
resource_cleanup(&buffer->resource); resource_cleanup(&buffer->resource);
buffer->resource.parent_ops->wined3d_object_destroyed(buffer->resource.parent); buffer->resource.parent_ops->wined3d_object_destroyed(buffer->resource.parent);
HeapFree(GetProcessHeap(), 0, buffer->maps); HeapFree(GetProcessHeap(), 0, buffer->maps);
......
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