Henri Verbeet : wined3d: Don' t evict resources that are currently mapped in wined3d_device_evict_managed_resources ().
Module: wine Branch: master Commit: 0d45d503420cbae1644cdc12697d86b3d84afbcf URL: http://source.winehq.org/git/wine.git/?a=commit;h=0d45d503420cbae1644cdc1269... Author: Henri Verbeet <hverbeet(a)codeweavers.com> Date: Mon May 21 20:48:35 2012 +0200 wined3d: Don't evict resources that are currently mapped in wined3d_device_evict_managed_resources(). --- dlls/wined3d/device.c | 2 +- dlls/wined3d/resource.c | 3 +++ 2 files changed, 4 insertions(+), 1 deletions(-) diff --git a/dlls/wined3d/device.c b/dlls/wined3d/device.c index dc0957a..a575eec 100644 --- a/dlls/wined3d/device.c +++ b/dlls/wined3d/device.c @@ -5096,7 +5096,7 @@ void CDECL wined3d_device_evict_managed_resources(struct wined3d_device *device) { TRACE("Checking resource %p for eviction.\n", resource); - if (resource->pool == WINED3D_POOL_MANAGED) + if (resource->pool == WINED3D_POOL_MANAGED && !resource->map_count) { TRACE("Evicting %p.\n", resource); resource->resource_ops->resource_unload(resource); diff --git a/dlls/wined3d/resource.c b/dlls/wined3d/resource.c index da631d6..3e1914d 100644 --- a/dlls/wined3d/resource.c +++ b/dlls/wined3d/resource.c @@ -171,6 +171,9 @@ void resource_cleanup(struct wined3d_resource *resource) void resource_unload(struct wined3d_resource *resource) { + if (resource->map_count) + ERR("Resource %p is being unloaded while mapped.\n", resource); + context_resource_unloaded(resource->device, resource, resource->type); }
participants (1)
-
Alexandre Julliard