From 6fba4c47fe43340188ba3f33b3384e89482da289 Mon Sep 17 00:00:00 2001 From: Philip Rebohle Date: Sat, 6 Aug 2022 01:37:17 +0200 Subject: [PATCH] [dxvk] Don't use MaxNumActiveBindings when creating descriptor set layouts --- src/dxvk/dxvk_pipelayout.cpp | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/src/dxvk/dxvk_pipelayout.cpp b/src/dxvk/dxvk_pipelayout.cpp index 895b685b..ef2cd26c 100644 --- a/src/dxvk/dxvk_pipelayout.cpp +++ b/src/dxvk/dxvk_pipelayout.cpp @@ -1,4 +1,5 @@ #include +#include #include "dxvk_device.h" #include "dxvk_descriptor.h" @@ -158,38 +159,43 @@ namespace dxvk { : m_device(device) { auto vk = m_device->vkd(); - std::array bindingInfos; - std::array templateInfos; + std::vector bindingInfos; + std::vector templateInfos; - VkDescriptorSetLayoutCreateInfo layoutInfo = { VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO }; - layoutInfo.bindingCount = key.getBindingCount(); - layoutInfo.pBindings = bindingInfos.data(); + bindingInfos.reserve(key.getBindingCount()); + templateInfos.reserve(key.getBindingCount()); for (uint32_t i = 0; i < key.getBindingCount(); i++) { auto entry = key.getBinding(i); - VkDescriptorSetLayoutBinding& bindingInfo = bindingInfos[i]; + VkDescriptorSetLayoutBinding bindingInfo; bindingInfo.binding = i; bindingInfo.descriptorType = entry.descriptorType; bindingInfo.descriptorCount = 1; bindingInfo.stageFlags = entry.stages; bindingInfo.pImmutableSamplers = nullptr; + bindingInfos.push_back(bindingInfo); - VkDescriptorUpdateTemplateEntry& templateInfo = templateInfos[i]; + VkDescriptorUpdateTemplateEntry templateInfo; templateInfo.dstBinding = i; templateInfo.dstArrayElement = 0; templateInfo.descriptorCount = 1; templateInfo.descriptorType = entry.descriptorType; templateInfo.offset = sizeof(DxvkDescriptorInfo) * i; templateInfo.stride = sizeof(DxvkDescriptorInfo); + templateInfos.push_back(templateInfo); } + VkDescriptorSetLayoutCreateInfo layoutInfo = { VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO }; + layoutInfo.bindingCount = bindingInfos.size(); + layoutInfo.pBindings = bindingInfos.data(); + if (vk->vkCreateDescriptorSetLayout(vk->device(), &layoutInfo, nullptr, &m_layout) != VK_SUCCESS) throw DxvkError("DxvkBindingSetLayoutKey: Failed to create descriptor set layout"); if (layoutInfo.bindingCount) { VkDescriptorUpdateTemplateCreateInfo templateInfo = { VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO }; - templateInfo.descriptorUpdateEntryCount = layoutInfo.bindingCount; + templateInfo.descriptorUpdateEntryCount = templateInfos.size(); templateInfo.pDescriptorUpdateEntries = templateInfos.data(); templateInfo.templateType = VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET; templateInfo.descriptorSetLayout = m_layout;