[PATCH 1/4] d3d10core: Implement d3d10_shader_resource_view_GetResource().

Henri Verbeet hverbeet at codeweavers.com
Wed Sep 12 04:30:51 CDT 2012


---
 dlls/d3d10core/d3d10core_private.h |    5 ++++-
 dlls/d3d10core/device.c            |    3 +--
 dlls/d3d10core/view.c              |   14 ++++++++++++--
 3 files changed, 17 insertions(+), 5 deletions(-)

diff --git a/dlls/d3d10core/d3d10core_private.h b/dlls/d3d10core/d3d10core_private.h
index 95d929a..f45fd34 100644
--- a/dlls/d3d10core/d3d10core_private.h
+++ b/dlls/d3d10core/d3d10core_private.h
@@ -155,9 +155,12 @@ struct d3d10_shader_resource_view
 {
     ID3D10ShaderResourceView ID3D10ShaderResourceView_iface;
     LONG refcount;
+
+    ID3D10Resource *resource;
 };
 
-HRESULT d3d10_shader_resource_view_init(struct d3d10_shader_resource_view *view) DECLSPEC_HIDDEN;
+HRESULT d3d10_shader_resource_view_init(struct d3d10_shader_resource_view *view,
+        ID3D10Resource *resource) DECLSPEC_HIDDEN;
 
 /* ID3D10InputLayout */
 struct d3d10_input_layout
diff --git a/dlls/d3d10core/device.c b/dlls/d3d10core/device.c
index 6cd7737..d184c02 100644
--- a/dlls/d3d10core/device.c
+++ b/dlls/d3d10core/device.c
@@ -746,8 +746,7 @@ static HRESULT STDMETHODCALLTYPE d3d10_device_CreateShaderResourceView(ID3D10Dev
         return E_OUTOFMEMORY;
     }
 
-    hr = d3d10_shader_resource_view_init(object);
-    if (FAILED(hr))
+    if (FAILED(hr = d3d10_shader_resource_view_init(object, resource)))
     {
         WARN("Failed to initialize shader resource view, hr %#x.\n", hr);
         HeapFree(GetProcessHeap(), 0, object);
diff --git a/dlls/d3d10core/view.c b/dlls/d3d10core/view.c
index 792e79b..9bf4fcb 100644
--- a/dlls/d3d10core/view.c
+++ b/dlls/d3d10core/view.c
@@ -526,6 +526,7 @@ static ULONG STDMETHODCALLTYPE d3d10_shader_resource_view_Release(ID3D10ShaderRe
 
     if (!refcount)
     {
+        ID3D10Resource_Release(This->resource);
         HeapFree(GetProcessHeap(), 0, This);
     }
 
@@ -571,7 +572,12 @@ static HRESULT STDMETHODCALLTYPE d3d10_shader_resource_view_SetPrivateDataInterf
 static void STDMETHODCALLTYPE d3d10_shader_resource_view_GetResource(ID3D10ShaderResourceView *iface,
         ID3D10Resource **resource)
 {
-    FIXME("iface %p, resource %p stub!\n", iface, resource);
+    struct d3d10_shader_resource_view *view = impl_from_ID3D10ShaderResourceView(iface);
+
+    TRACE("iface %p, resource %p.\n", iface, resource);
+
+    *resource = view->resource;
+    ID3D10Resource_AddRef(*resource);
 }
 
 /* ID3D10ShaderResourceView methods */
@@ -599,10 +605,14 @@ static const struct ID3D10ShaderResourceViewVtbl d3d10_shader_resource_view_vtbl
     d3d10_shader_resource_view_GetDesc,
 };
 
-HRESULT d3d10_shader_resource_view_init(struct d3d10_shader_resource_view *view)
+HRESULT d3d10_shader_resource_view_init(struct d3d10_shader_resource_view *view,
+        ID3D10Resource *resource)
 {
     view->ID3D10ShaderResourceView_iface.lpVtbl = &d3d10_shader_resource_view_vtbl;
     view->refcount = 1;
 
+    view->resource = resource;
+    ID3D10Resource_AddRef(resource);
+
     return S_OK;
 }
-- 
1.7.8.6




More information about the wine-patches mailing list