[PATCH 4/8] d3d11: Implement d3d10_query_GetData().
Józef Kucia
jkucia at codeweavers.com
Thu Jul 7 05:22:31 CDT 2016
Signed-off-by: Józef Kucia <jkucia at codeweavers.com>
---
dlls/d3d11/async.c | 22 ++++++++++++++++++++--
1 file changed, 20 insertions(+), 2 deletions(-)
diff --git a/dlls/d3d11/async.c b/dlls/d3d11/async.c
index 2e57ed6..fa38484 100644
--- a/dlls/d3d11/async.c
+++ b/dlls/d3d11/async.c
@@ -292,9 +292,27 @@ static void STDMETHODCALLTYPE d3d10_query_End(ID3D10Query *iface)
static HRESULT STDMETHODCALLTYPE d3d10_query_GetData(ID3D10Query *iface, void *data, UINT data_size, UINT flags)
{
- FIXME("iface %p, data %p, data_size %u, flags %#x stub!\n", iface, data, data_size, flags);
+ struct d3d_query *query = impl_from_ID3D10Query(iface);
+ unsigned int wined3d_flags;
+ HRESULT hr;
+
+ TRACE("iface %p, data %p, data_size %u, flags %#x.\n", iface, data, data_size, flags);
+
+ wined3d_flags = wined3d_getdata_flags_from_d3d11_async_getdata_flags(flags);
+
+ wined3d_mutex_lock();
+ if (!data_size || wined3d_query_get_data_size(query->wined3d_query) == data_size)
+ {
+ hr = wined3d_query_get_data(query->wined3d_query, data, data_size, wined3d_flags);
+ }
+ else
+ {
+ WARN("Invalid data size %u.\n", data_size);
+ hr = E_INVALIDARG;
+ }
+ wined3d_mutex_unlock();
- return E_NOTIMPL;
+ return hr;
}
static UINT STDMETHODCALLTYPE d3d10_query_GetDataSize(ID3D10Query *iface)
--
2.7.3
More information about the wine-patches
mailing list