[PATCH vkd3d 3/5] vkd3d: Implement set name for resources.

Zhiyi Zhang zzhang at codeweavers.com
Sat Jan 26 02:31:48 CST 2019


Signed-off-by: Zhiyi Zhang <zzhang at codeweavers.com>
---
 libs/vkd3d/resource.c      | 23 +++++++++++++++++++++--
 libs/vkd3d/vkd3d_private.h |  1 +
 2 files changed, 22 insertions(+), 2 deletions(-)

diff --git a/libs/vkd3d/resource.c b/libs/vkd3d/resource.c
index 7afcaea..3f8e05e 100644
--- a/libs/vkd3d/resource.c
+++ b/libs/vkd3d/resource.c
@@ -736,6 +736,7 @@ static ULONG d3d12_resource_decref(struct d3d12_resource *resource)
 
     if (!refcount)
     {
+        if (resource->name) vkd3d_free(resource->name);
         vkd3d_private_store_destroy(&resource->private_store);
         d3d12_resource_destroy(resource, resource->device);
         vkd3d_free(resource);
@@ -842,10 +843,27 @@ static HRESULT STDMETHODCALLTYPE d3d12_resource_SetPrivateDataInterface(ID3D12Re
 static HRESULT STDMETHODCALLTYPE d3d12_resource_SetName(ID3D12Resource *iface, const WCHAR *name)
 {
     struct d3d12_resource *resource = impl_from_ID3D12Resource(iface);
+    HRESULT hr;
 
-    FIXME("iface %p, name %s stub!\n", iface, debugstr_w(name, resource->device->wchar_size));
+    TRACE("iface %p, name %s.\n", iface, debugstr_w(name, resource->device->wchar_size));
 
-    return E_NOTIMPL;
+    if (resource->vk_memory)
+    {
+        hr = vkd3d_set_vk_object_name(resource->device, (uint64_t)resource->vk_memory,
+                                      VK_DEBUG_REPORT_OBJECT_TYPE_DEVICE_MEMORY_EXT, name);
+        if (FAILED(hr)) return hr;
+    }
+
+    if (d3d12_resource_is_buffer(resource))
+        hr = vkd3d_set_vk_object_name(resource->device, (uint64_t)resource->u.vk_buffer,
+                                      VK_DEBUG_REPORT_OBJECT_TYPE_BUFFER_EXT, name);
+    else
+        hr = vkd3d_set_vk_object_name(resource->device, (uint64_t)resource->u.vk_image,
+                                      VK_DEBUG_REPORT_OBJECT_TYPE_IMAGE_EXT, name);
+
+    if (FAILED(hr)) return hr;
+
+    return vkd3d_set_name(&resource->name, name, resource->device->wchar_size);
 }
 
 static HRESULT STDMETHODCALLTYPE d3d12_resource_GetDevice(ID3D12Resource *iface,
@@ -1118,6 +1136,7 @@ static HRESULT d3d12_resource_init(struct d3d12_resource *resource, struct d3d12
     resource->ID3D12Resource_iface.lpVtbl = &d3d12_resource_vtbl;
     resource->refcount = 1;
     resource->internal_refcount = 1;
+    resource->name = NULL;
 
     resource->desc = *desc;
 
diff --git a/libs/vkd3d/vkd3d_private.h b/libs/vkd3d/vkd3d_private.h
index eb4d794..fbabc39 100644
--- a/libs/vkd3d/vkd3d_private.h
+++ b/libs/vkd3d/vkd3d_private.h
@@ -292,6 +292,7 @@ struct d3d12_resource
     ID3D12Resource ID3D12Resource_iface;
     LONG refcount;
     LONG internal_refcount;
+    WCHAR *name;
 
     D3D12_RESOURCE_DESC desc;
 
-- 
2.19.2





More information about the wine-devel mailing list