d3d9: Implement IDirect3DVolume9 private data handling on top of wined3d_resource.
This commit is contained in:
parent
7a8a7b920e
commit
52fd36b68b
|
@ -126,13 +126,15 @@ static HRESULT WINAPI IDirect3DVolume9Impl_SetPrivateData(IDirect3DVolume9 *ifac
|
||||||
const void *pData, DWORD SizeOfData, DWORD Flags)
|
const void *pData, DWORD SizeOfData, DWORD Flags)
|
||||||
{
|
{
|
||||||
IDirect3DVolume9Impl *This = impl_from_IDirect3DVolume9(iface);
|
IDirect3DVolume9Impl *This = impl_from_IDirect3DVolume9(iface);
|
||||||
|
struct wined3d_resource *resource;
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
|
|
||||||
TRACE("iface %p, guid %s, data %p, data_size %u, flags %#x.\n",
|
TRACE("iface %p, guid %s, data %p, data_size %u, flags %#x.\n",
|
||||||
iface, debugstr_guid(refguid), pData, SizeOfData, Flags);
|
iface, debugstr_guid(refguid), pData, SizeOfData, Flags);
|
||||||
|
|
||||||
wined3d_mutex_lock();
|
wined3d_mutex_lock();
|
||||||
hr = wined3d_volume_set_private_data(This->wined3d_volume, refguid, pData, SizeOfData, Flags);
|
resource = wined3d_volume_get_resource(This->wined3d_volume);
|
||||||
|
hr = wined3d_resource_set_private_data(resource, refguid, pData, SizeOfData, Flags);
|
||||||
wined3d_mutex_unlock();
|
wined3d_mutex_unlock();
|
||||||
|
|
||||||
return hr;
|
return hr;
|
||||||
|
@ -142,13 +144,15 @@ static HRESULT WINAPI IDirect3DVolume9Impl_GetPrivateData(IDirect3DVolume9 *ifac
|
||||||
void *pData, DWORD *pSizeOfData)
|
void *pData, DWORD *pSizeOfData)
|
||||||
{
|
{
|
||||||
IDirect3DVolume9Impl *This = impl_from_IDirect3DVolume9(iface);
|
IDirect3DVolume9Impl *This = impl_from_IDirect3DVolume9(iface);
|
||||||
|
struct wined3d_resource *resource;
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
|
|
||||||
TRACE("iface %p, guid %s, data %p, data_size %p.\n",
|
TRACE("iface %p, guid %s, data %p, data_size %p.\n",
|
||||||
iface, debugstr_guid(refguid), pData, pSizeOfData);
|
iface, debugstr_guid(refguid), pData, pSizeOfData);
|
||||||
|
|
||||||
wined3d_mutex_lock();
|
wined3d_mutex_lock();
|
||||||
hr = wined3d_volume_get_private_data(This->wined3d_volume, refguid, pData, pSizeOfData);
|
resource = wined3d_volume_get_resource(This->wined3d_volume);
|
||||||
|
hr = wined3d_resource_get_private_data(resource, refguid, pData, pSizeOfData);
|
||||||
wined3d_mutex_unlock();
|
wined3d_mutex_unlock();
|
||||||
|
|
||||||
return hr;
|
return hr;
|
||||||
|
@ -157,12 +161,14 @@ static HRESULT WINAPI IDirect3DVolume9Impl_GetPrivateData(IDirect3DVolume9 *ifac
|
||||||
static HRESULT WINAPI IDirect3DVolume9Impl_FreePrivateData(IDirect3DVolume9 *iface, REFGUID refguid)
|
static HRESULT WINAPI IDirect3DVolume9Impl_FreePrivateData(IDirect3DVolume9 *iface, REFGUID refguid)
|
||||||
{
|
{
|
||||||
IDirect3DVolume9Impl *This = impl_from_IDirect3DVolume9(iface);
|
IDirect3DVolume9Impl *This = impl_from_IDirect3DVolume9(iface);
|
||||||
|
struct wined3d_resource *resource;
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
|
|
||||||
TRACE("iface %p, guid %s.\n", iface, debugstr_guid(refguid));
|
TRACE("iface %p, guid %s.\n", iface, debugstr_guid(refguid));
|
||||||
|
|
||||||
wined3d_mutex_lock();
|
wined3d_mutex_lock();
|
||||||
hr = wined3d_volume_free_private_data(This->wined3d_volume, refguid);
|
resource = wined3d_volume_get_resource(This->wined3d_volume);
|
||||||
|
hr = wined3d_resource_free_private_data(resource, refguid);
|
||||||
wined3d_mutex_unlock();
|
wined3d_mutex_unlock();
|
||||||
|
|
||||||
return hr;
|
return hr;
|
||||||
|
|
Loading…
Reference in New Issue