summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/video_core/renderer_vulkan/vk_device.cpp15
1 files changed, 9 insertions, 6 deletions
diff --git a/src/video_core/renderer_vulkan/vk_device.cpp b/src/video_core/renderer_vulkan/vk_device.cpp
index 030b4dbd3..4205bd573 100644
--- a/src/video_core/renderer_vulkan/vk_device.cpp
+++ b/src/video_core/renderer_vulkan/vk_device.cpp
@@ -380,6 +380,14 @@ bool VKDevice::Create() {
380 380
381 CollectTelemetryParameters(); 381 CollectTelemetryParameters();
382 382
383 if (ext_extended_dynamic_state && driver_id == VK_DRIVER_ID_AMD_PROPRIETARY_KHR) {
384 // AMD's proprietary driver supports VK_EXT_extended_dynamic_state but the <stride> field
385 // seems to be bugged. Blacklisting it for now.
386 LOG_WARNING(Render_Vulkan,
387 "Blacklisting AMD proprietary from VK_EXT_extended_dynamic_state");
388 ext_extended_dynamic_state = false;
389 }
390
383 graphics_queue = logical.GetQueue(graphics_family); 391 graphics_queue = logical.GetQueue(graphics_family);
384 present_queue = logical.GetQueue(present_family); 392 present_queue = logical.GetQueue(present_family);
385 393
@@ -691,12 +699,7 @@ std::vector<const char*> VKDevice::LoadExtensions() {
691 } 699 }
692 } 700 }
693 701
694 if (has_ext_extended_dynamic_state && driver_id == VK_DRIVER_ID_AMD_PROPRIETARY) { 702 if (has_ext_extended_dynamic_state) {
695 // AMD's proprietary driver supports VK_EXT_extended_dynamic_state but the <stride> field
696 // seems to be bugged. Blacklisting it for now.
697 LOG_WARNING(Render_Vulkan,
698 "Blacklisting AMD proprietary from VK_EXT_extended_dynamic_state");
699 } else if (has_ext_extended_dynamic_state) {
700 VkPhysicalDeviceExtendedDynamicStateFeaturesEXT dynamic_state; 703 VkPhysicalDeviceExtendedDynamicStateFeaturesEXT dynamic_state;
701 dynamic_state.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTENDED_DYNAMIC_STATE_FEATURES_EXT; 704 dynamic_state.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTENDED_DYNAMIC_STATE_FEATURES_EXT;
702 dynamic_state.pNext = nullptr; 705 dynamic_state.pNext = nullptr;