=?UTF-8?Q?J=C3=B3zef=20Kucia=20?=: d3d11: Implement private data methods in ID3D11Texture2D.
Alexandre Julliard
julliard at wine.codeweavers.com
Wed Aug 26 09:57:11 CDT 2015
Module: wine
Branch: master
Commit: 3c74e223179ce80355962cf524c0321dee9fad4a
URL: http://source.winehq.org/git/wine.git/?a=commit;h=3c74e223179ce80355962cf524c0321dee9fad4a
Author: Józef Kucia <jkucia at codeweavers.com>
Date: Wed Aug 26 00:56:05 2015 +0200
d3d11: Implement private data methods in ID3D11Texture2D.
---
dlls/d3d11/texture.c | 90 +++++++++++++++++++++++++++-------------------------
1 file changed, 47 insertions(+), 43 deletions(-)
diff --git a/dlls/d3d11/texture.c b/dlls/d3d11/texture.c
index d5137e7..940567a 100644
--- a/dlls/d3d11/texture.c
+++ b/dlls/d3d11/texture.c
@@ -115,25 +115,61 @@ static void STDMETHODCALLTYPE d3d11_texture2d_GetDevice(ID3D11Texture2D *iface,
static HRESULT STDMETHODCALLTYPE d3d11_texture2d_GetPrivateData(ID3D11Texture2D *iface,
REFGUID guid, UINT *data_size, void *data)
{
- FIXME("iface %p, guid %s, data_size %p, data %p stub!\n", iface, debugstr_guid(guid), data_size, data);
+ struct d3d10_texture2d *texture = impl_from_ID3D11Texture2D(iface);
+ IDXGISurface *dxgi_surface;
+ HRESULT hr;
+
+ TRACE("iface %p, guid %s, data_size %p, data %p.\n", iface, debugstr_guid(guid), data_size, data);
+
+ if (texture->dxgi_surface
+ && SUCCEEDED(IUnknown_QueryInterface(texture->dxgi_surface, &IID_IDXGISurface, (void **)&dxgi_surface)))
+ {
+ hr = IDXGISurface_GetPrivateData(dxgi_surface, guid, data_size, data);
+ IDXGISurface_Release(dxgi_surface);
+ return hr;
+ }
- return E_NOTIMPL;
+ return d3d10_get_private_data(&texture->private_store, guid, data_size, data);
}
static HRESULT STDMETHODCALLTYPE d3d11_texture2d_SetPrivateData(ID3D11Texture2D *iface,
REFGUID guid, UINT data_size, const void *data)
{
- FIXME("iface %p, guid %s, data_size %u, data %p stub!\n", iface, debugstr_guid(guid), data_size, data);
+ struct d3d10_texture2d *texture = impl_from_ID3D11Texture2D(iface);
+ IDXGISurface *dxgi_surface;
+ HRESULT hr;
+
+ TRACE("iface %p, guid %s, data_size %u, data %p.\n", iface, debugstr_guid(guid), data_size, data);
- return E_NOTIMPL;
+ if (texture->dxgi_surface
+ && SUCCEEDED(IUnknown_QueryInterface(texture->dxgi_surface, &IID_IDXGISurface, (void **)&dxgi_surface)))
+ {
+ hr = IDXGISurface_SetPrivateData(dxgi_surface, guid, data_size, data);
+ IDXGISurface_Release(dxgi_surface);
+ return hr;
+ }
+
+ return d3d10_set_private_data(&texture->private_store, guid, data_size, data);
}
static HRESULT STDMETHODCALLTYPE d3d11_texture2d_SetPrivateDataInterface(ID3D11Texture2D *iface,
REFGUID guid, const IUnknown *data)
{
- FIXME("iface %p, guid %s, data %p stub!\n", iface, debugstr_guid(guid), data);
+ struct d3d10_texture2d *texture = impl_from_ID3D11Texture2D(iface);
+ IDXGISurface *dxgi_surface;
+ HRESULT hr;
+
+ TRACE("iface %p, guid %s, data %p.\n", iface, debugstr_guid(guid), data);
+
+ if (texture->dxgi_surface
+ && SUCCEEDED(IUnknown_QueryInterface(texture->dxgi_surface, &IID_IDXGISurface, (void **)&dxgi_surface)))
+ {
+ hr = IDXGISurface_SetPrivateDataInterface(dxgi_surface, guid, data);
+ IDXGISurface_Release(dxgi_surface);
+ return hr;
+ }
- return E_NOTIMPL;
+ return d3d10_set_private_data_interface(&texture->private_store, guid, data);
}
static void STDMETHODCALLTYPE d3d11_texture2d_GetType(ID3D11Texture2D *iface,
@@ -234,62 +270,30 @@ static HRESULT STDMETHODCALLTYPE d3d10_texture2d_GetPrivateData(ID3D10Texture2D
REFGUID guid, UINT *data_size, void *data)
{
struct d3d10_texture2d *texture = impl_from_ID3D10Texture2D(iface);
- IDXGISurface *dxgi_surface;
- HRESULT hr;
- TRACE("iface %p, guid %s, data_size %p, data %p.\n",
- iface, debugstr_guid(guid), data_size, data);
+ TRACE("iface %p, guid %s, data_size %p, data %p.\n", iface, debugstr_guid(guid), data_size, data);
- if (texture->dxgi_surface
- && SUCCEEDED(IUnknown_QueryInterface(texture->dxgi_surface, &IID_IDXGISurface, (void **)&dxgi_surface)))
- {
- hr = IDXGISurface_GetPrivateData(dxgi_surface, guid, data_size, data);
- IDXGISurface_Release(dxgi_surface);
- return hr;
- }
-
- return d3d10_get_private_data(&texture->private_store, guid, data_size, data);
+ return d3d11_texture2d_GetPrivateData(&texture->ID3D11Texture2D_iface, guid, data_size, data);
}
static HRESULT STDMETHODCALLTYPE d3d10_texture2d_SetPrivateData(ID3D10Texture2D *iface,
REFGUID guid, UINT data_size, const void *data)
{
struct d3d10_texture2d *texture = impl_from_ID3D10Texture2D(iface);
- IDXGISurface *dxgi_surface;
- HRESULT hr;
-
- TRACE("iface %p, guid %s, data_size %u, data %p.\n",
- iface, debugstr_guid(guid), data_size, data);
- if (texture->dxgi_surface
- && SUCCEEDED(IUnknown_QueryInterface(texture->dxgi_surface, &IID_IDXGISurface, (void **)&dxgi_surface)))
- {
- hr = IDXGISurface_SetPrivateData(dxgi_surface, guid, data_size, data);
- IDXGISurface_Release(dxgi_surface);
- return hr;
- }
+ TRACE("iface %p, guid %s, data_size %u, data %p.\n", iface, debugstr_guid(guid), data_size, data);
- return d3d10_set_private_data(&texture->private_store, guid, data_size, data);
+ return d3d11_texture2d_SetPrivateData(&texture->ID3D11Texture2D_iface, guid, data_size, data);
}
static HRESULT STDMETHODCALLTYPE d3d10_texture2d_SetPrivateDataInterface(ID3D10Texture2D *iface,
REFGUID guid, const IUnknown *data)
{
struct d3d10_texture2d *texture = impl_from_ID3D10Texture2D(iface);
- IDXGISurface *dxgi_surface;
- HRESULT hr;
TRACE("iface %p, guid %s, data %p.\n", iface, debugstr_guid(guid), data);
- if (texture->dxgi_surface
- && SUCCEEDED(IUnknown_QueryInterface(texture->dxgi_surface, &IID_IDXGISurface, (void **)&dxgi_surface)))
- {
- hr = IDXGISurface_SetPrivateDataInterface(dxgi_surface, guid, data);
- IDXGISurface_Release(dxgi_surface);
- return hr;
- }
-
- return d3d10_set_private_data_interface(&texture->private_store, guid, data);
+ return d3d11_texture2d_SetPrivateDataInterface(&texture->ID3D11Texture2D_iface, guid, data);
}
/* ID3D10Resource methods */
More information about the wine-cvs
mailing list