diff --git a/src/video_core/vulkan_common/vulkan_device.cpp b/src/video_core/vulkan_common/vulkan_device.cpp index 06a2169255..cc4572773d 100644 --- a/src/video_core/vulkan_common/vulkan_device.cpp +++ b/src/video_core/vulkan_common/vulkan_device.cpp @@ -485,27 +485,43 @@ Device::Device(VkInstance instance_, vk::PhysicalDevice physical_, VkSurfaceKHR } // VK_EXT_descriptor_buffer + VkPhysicalDeviceDescriptorBufferFeaturesEXT descriptor_buffer_temp{}; + descriptor_buffer_temp.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_BUFFER_FEATURES_EXT; + descriptor_buffer_temp.pNext = nullptr; + VkPhysicalDeviceFeatures2 db_features2{}; + db_features2.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2; + db_features2.pNext = &descriptor_buffer_temp; + physical.GetFeatures2(db_features2); + VkPhysicalDeviceDescriptorBufferFeaturesEXT descriptor_buffer_features{ .sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_BUFFER_FEATURES_EXT, .pNext = first_next, - .descriptorBuffer = features.descriptor_buffer.descriptorBuffer ? VK_TRUE : VK_FALSE, - .descriptorBufferCaptureReplay = features.descriptor_buffer.descriptorBufferCaptureReplay ? VK_TRUE : VK_FALSE, - .descriptorBufferImageLayoutIgnored = features.descriptor_buffer.descriptorBufferImageLayoutIgnored ? VK_TRUE : VK_FALSE, - .descriptorBufferPushDescriptors = features.descriptor_buffer.descriptorBufferPushDescriptors ? VK_TRUE : VK_FALSE, + .descriptorBuffer = descriptor_buffer_temp.descriptorBuffer ? VK_TRUE : VK_FALSE, + .descriptorBufferCaptureReplay = descriptor_buffer_temp.descriptorBufferCaptureReplay ? VK_TRUE : VK_FALSE, + .descriptorBufferImageLayoutIgnored = descriptor_buffer_temp.descriptorBufferImageLayoutIgnored ? VK_TRUE : VK_FALSE, + .descriptorBufferPushDescriptors = descriptor_buffer_temp.descriptorBufferPushDescriptors ? VK_TRUE : VK_FALSE, }; - if (extensions.descriptor_buffer) { + if (extensions.descriptor_buffer && descriptor_buffer_temp.descriptorBuffer) { first_next = &descriptor_buffer_features; } // VK_EXT_inline_uniform_block + VkPhysicalDeviceInlineUniformBlockFeaturesEXT inline_uniform_block_temp{}; + inline_uniform_block_temp.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_INLINE_UNIFORM_BLOCK_FEATURES_EXT; + inline_uniform_block_temp.pNext = nullptr; + VkPhysicalDeviceFeatures2 iub_features2{}; + iub_features2.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2; + iub_features2.pNext = &inline_uniform_block_temp; + physical.GetFeatures2(iub_features2); + VkPhysicalDeviceInlineUniformBlockFeaturesEXT inline_uniform_block_features{ .sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_INLINE_UNIFORM_BLOCK_FEATURES_EXT, .pNext = first_next, - .inlineUniformBlock = features.inline_uniform_block.inlineUniformBlock ? VK_TRUE : VK_FALSE, + .inlineUniformBlock = inline_uniform_block_temp.inlineUniformBlock ? VK_TRUE : VK_FALSE, }; - if (extensions.inline_uniform_block && features.inline_uniform_block.inlineUniformBlock) { + if (extensions.inline_uniform_block && inline_uniform_block_temp.inlineUniformBlock) { first_next = &inline_uniform_block_features; }