Commit 18611310 authored by Józef Kucia's avatar Józef Kucia Committed by Alexandre Julliard

d3d11: Do not store ID3D11Device pointer in d3d11_immediate_context.

parent 3b02ae89
...@@ -370,7 +370,6 @@ struct d3d11_immediate_context ...@@ -370,7 +370,6 @@ struct d3d11_immediate_context
{ {
ID3D11DeviceContext ID3D11DeviceContext_iface; ID3D11DeviceContext ID3D11DeviceContext_iface;
LONG refcount; LONG refcount;
ID3D11Device *device;
}; };
/* ID3D11Device, ID3D10Device1 */ /* ID3D11Device, ID3D10Device1 */
......
...@@ -67,13 +67,14 @@ static HRESULT STDMETHODCALLTYPE d3d11_immediate_context_QueryInterface(ID3D11De ...@@ -67,13 +67,14 @@ static HRESULT STDMETHODCALLTYPE d3d11_immediate_context_QueryInterface(ID3D11De
static ULONG STDMETHODCALLTYPE d3d11_immediate_context_AddRef(ID3D11DeviceContext *iface) static ULONG STDMETHODCALLTYPE d3d11_immediate_context_AddRef(ID3D11DeviceContext *iface)
{ {
struct d3d11_immediate_context *context = impl_from_ID3D11DeviceContext(iface); struct d3d11_immediate_context *context = impl_from_ID3D11DeviceContext(iface);
struct d3d_device *device = device_from_immediate_ID3D11DeviceContext(iface);
ULONG refcount = InterlockedIncrement(&context->refcount); ULONG refcount = InterlockedIncrement(&context->refcount);
TRACE("%p increasing refcount to %u.\n", context, refcount); TRACE("%p increasing refcount to %u.\n", context, refcount);
if (refcount == 1) if (refcount == 1)
{ {
ID3D11Device_AddRef(context->device); ID3D11Device_AddRef(&device->ID3D11Device_iface);
} }
return refcount; return refcount;
...@@ -82,13 +83,14 @@ static ULONG STDMETHODCALLTYPE d3d11_immediate_context_AddRef(ID3D11DeviceContex ...@@ -82,13 +83,14 @@ static ULONG STDMETHODCALLTYPE d3d11_immediate_context_AddRef(ID3D11DeviceContex
static ULONG STDMETHODCALLTYPE d3d11_immediate_context_Release(ID3D11DeviceContext *iface) static ULONG STDMETHODCALLTYPE d3d11_immediate_context_Release(ID3D11DeviceContext *iface)
{ {
struct d3d11_immediate_context *context = impl_from_ID3D11DeviceContext(iface); struct d3d11_immediate_context *context = impl_from_ID3D11DeviceContext(iface);
struct d3d_device *device = device_from_immediate_ID3D11DeviceContext(iface);
ULONG refcount = InterlockedDecrement(&context->refcount); ULONG refcount = InterlockedDecrement(&context->refcount);
TRACE("%p decreasing refcount to %u.\n", context, refcount); TRACE("%p decreasing refcount to %u.\n", context, refcount);
if (!refcount) if (!refcount)
{ {
ID3D11Device_Release(context->device); ID3D11Device_Release(&device->ID3D11Device_iface);
} }
return refcount; return refcount;
...@@ -96,11 +98,11 @@ static ULONG STDMETHODCALLTYPE d3d11_immediate_context_Release(ID3D11DeviceConte ...@@ -96,11 +98,11 @@ static ULONG STDMETHODCALLTYPE d3d11_immediate_context_Release(ID3D11DeviceConte
static void STDMETHODCALLTYPE d3d11_immediate_context_GetDevice(ID3D11DeviceContext *iface, ID3D11Device **device) static void STDMETHODCALLTYPE d3d11_immediate_context_GetDevice(ID3D11DeviceContext *iface, ID3D11Device **device)
{ {
struct d3d11_immediate_context *context = impl_from_ID3D11DeviceContext(iface); struct d3d_device *device_object = device_from_immediate_ID3D11DeviceContext(iface);
TRACE("iface %p, device %p.\n", iface, device); TRACE("iface %p, device %p.\n", iface, device);
*device = context->device; *device = &device_object->ID3D11Device_iface;
ID3D11Device_AddRef(*device); ID3D11Device_AddRef(*device);
} }
...@@ -1057,8 +1059,7 @@ static HRESULT d3d11_immediate_context_init(struct d3d11_immediate_context *cont ...@@ -1057,8 +1059,7 @@ static HRESULT d3d11_immediate_context_init(struct d3d11_immediate_context *cont
context->ID3D11DeviceContext_iface.lpVtbl = &d3d11_immediate_context_vtbl; context->ID3D11DeviceContext_iface.lpVtbl = &d3d11_immediate_context_vtbl;
context->refcount = 1; context->refcount = 1;
context->device = &device->ID3D11Device_iface; ID3D11Device_AddRef(&device->ID3D11Device_iface);
ID3D11Device_AddRef(context->device);
return S_OK; return S_OK;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment