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

This commit is contained in:
Henri Verbeet 2012-05-02 21:47:54 +02:00 committed by Alexandre Julliard
parent c9fdc565e5
commit 46a6f4c1a9
1 changed files with 5 additions and 2 deletions

View File

@ -1184,6 +1184,7 @@ static HRESULT WINAPI d3d9_texture_3d_LockBox(IDirect3DVolumeTexture9 *iface,
{ {
struct d3d9_texture *texture = impl_from_IDirect3DVolumeTexture9(iface); struct d3d9_texture *texture = impl_from_IDirect3DVolumeTexture9(iface);
struct wined3d_resource *sub_resource; struct wined3d_resource *sub_resource;
IDirect3DVolume9Impl *volume_impl;
HRESULT hr; HRESULT hr;
TRACE("iface %p, level %u, locked_box %p, box %p, flags %#x.\n", TRACE("iface %p, level %u, locked_box %p, box %p, flags %#x.\n",
@ -1193,8 +1194,10 @@ static HRESULT WINAPI d3d9_texture_3d_LockBox(IDirect3DVolumeTexture9 *iface,
if (!(sub_resource = wined3d_texture_get_sub_resource(texture->wined3d_texture, level))) if (!(sub_resource = wined3d_texture_get_sub_resource(texture->wined3d_texture, level)))
hr = D3DERR_INVALIDCALL; hr = D3DERR_INVALIDCALL;
else else
hr = IDirect3DVolume9_LockBox((IDirect3DVolume9 *)wined3d_resource_get_parent(sub_resource), {
locked_box, box, flags); volume_impl = wined3d_resource_get_parent(sub_resource);
hr = IDirect3DVolume9_LockBox(&volume_impl->IDirect3DVolume9_iface, locked_box, box, flags);
}
wined3d_mutex_unlock(); wined3d_mutex_unlock();
return hr; return hr;