Henri Verbeet : d3d9: Properly retrieve an interface pointer in d3d9_texture_2d_UnlockRect().

Alexandre Julliard julliard at winehq.org
Tue May 1 13:12:13 CDT 2012


Module: wine
Branch: master
Commit: c85f6c9419ca9ac9ea2c3e165c4f2d348c79f014
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=c85f6c9419ca9ac9ea2c3e165c4f2d348c79f014

Author: Henri Verbeet <hverbeet at codeweavers.com>
Date:   Mon Apr 30 21:30:18 2012 +0200

d3d9: Properly retrieve an interface pointer in d3d9_texture_2d_UnlockRect().

---

 dlls/d3d9/texture.c |    6 +++++-
 1 files changed, 5 insertions(+), 1 deletions(-)

diff --git a/dlls/d3d9/texture.c b/dlls/d3d9/texture.c
index bbe7808..bc39ed2 100644
--- a/dlls/d3d9/texture.c
+++ b/dlls/d3d9/texture.c
@@ -373,6 +373,7 @@ static HRESULT WINAPI d3d9_texture_2d_UnlockRect(IDirect3DTexture9 *iface, UINT
 {
     struct d3d9_texture *texture = impl_from_IDirect3DTexture9(iface);
     struct wined3d_resource *sub_resource;
+    IDirect3DSurface9Impl *surface_impl;
     HRESULT hr;
 
     TRACE("iface %p, level %u.\n", iface, level);
@@ -381,7 +382,10 @@ static HRESULT WINAPI d3d9_texture_2d_UnlockRect(IDirect3DTexture9 *iface, UINT
     if (!(sub_resource = wined3d_texture_get_sub_resource(texture->wined3d_texture, level)))
         hr = D3DERR_INVALIDCALL;
     else
-        hr = IDirect3DSurface9_UnlockRect((IDirect3DSurface9 *)wined3d_resource_get_parent(sub_resource));
+    {
+        surface_impl = wined3d_resource_get_parent(sub_resource);
+        hr = IDirect3DSurface9_UnlockRect(&surface_impl->IDirect3DSurface9_iface);
+    }
     wined3d_mutex_unlock();
 
     return hr;




More information about the wine-cvs mailing list