[PATCH vkd3d 05/11] vkd3d: Implement support for D3D12_FEATURE_COMMAND_QUEUE_PRIORITY.

Conor McCarthy conor.mccarthy.444 at gmail.com
Tue May 19 08:46:53 CDT 2020


Signed-off-by: Conor McCarthy <conor.mccarthy.444 at gmail.com>
---
 include/vkd3d_d3d12.idl |  7 +++++++
 libs/vkd3d/device.c     | 26 ++++++++++++++++++++++++++
 2 files changed, 33 insertions(+)

diff --git a/include/vkd3d_d3d12.idl b/include/vkd3d_d3d12.idl
index 60f36b4..6e674a0 100644
--- a/include/vkd3d_d3d12.idl
+++ b/include/vkd3d_d3d12.idl
@@ -1654,6 +1654,13 @@ typedef struct D3D12_FEATURE_DATA_SHADER_CACHE
     D3D12_SHADER_CACHE_SUPPORT_FLAGS SupportFlags;
 }  D3D12_FEATURE_DATA_SHADER_CACHE;
 
+typedef struct D3D12_FEATURE_DATA_COMMAND_QUEUE_PRIORITY
+{
+    D3D12_COMMAND_LIST_TYPE CommandListType;
+    UINT Priority;
+    BOOL PriorityForTypeIsSupported;
+}  D3D12_FEATURE_DATA_COMMAND_QUEUE_PRIORITY;
+
 typedef enum D3D12_FEATURE
 {
     D3D12_FEATURE_D3D12_OPTIONS = 0,
diff --git a/libs/vkd3d/device.c b/libs/vkd3d/device.c
index 694c322..8bae29d 100644
--- a/libs/vkd3d/device.c
+++ b/libs/vkd3d/device.c
@@ -2785,6 +2785,32 @@ static HRESULT STDMETHODCALLTYPE d3d12_device_CheckFeatureSupport(ID3D12Device *
             return S_OK;
         }
 
+        case D3D12_FEATURE_COMMAND_QUEUE_PRIORITY:
+        {
+            D3D12_FEATURE_DATA_COMMAND_QUEUE_PRIORITY *data = feature_data;
+
+            if (feature_data_size != sizeof(*data))
+            {
+                WARN("Invalid size %u.\n", feature_data_size);
+                return E_INVALIDARG;
+            }
+
+            switch (data->CommandListType)
+            {
+                case D3D12_COMMAND_LIST_TYPE_DIRECT:
+                case D3D12_COMMAND_LIST_TYPE_COMPUTE:
+                case D3D12_COMMAND_LIST_TYPE_COPY:
+                    data->PriorityForTypeIsSupported = FALSE;
+                    TRACE("Command list type %#x, priority %u, supported %#x.\n",
+                            data->CommandListType, data->Priority, data->PriorityForTypeIsSupported);
+                    return S_OK;
+
+                default:
+                    FIXME("Unhandled command list type %#x.\n", data->CommandListType);
+                    return E_INVALIDARG;
+            }
+        }
+
         default:
             FIXME("Unhandled feature %#x.\n", feature);
             return E_NOTIMPL;
-- 
2.24.0



More information about the wine-devel mailing list