diff options
| author | Morph <39850852+Morph1984@users.noreply.github.com> | 2021-09-13 17:25:56 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-09-13 17:25:56 -0400 | 
| commit | 62e88d0e7455e37840db7e2a8e199bc6ca176966 (patch) | |
| tree | cf15674ea1ed3c6be239f52c409e628d1dba1787 | |
| parent | edf3da346f4ec0ca492b427f4f693d56e84abc52 (diff) | |
| parent | e7c8a0bb23aa0183bbfcb616d09131e825ac8d04 (diff) | |
Merge pull request #7006 from FernandoS27/a-motherfucking-driver
Vulkan: Blacklist Int8Float16 Extension on AMD on driver 21.9.1
| -rw-r--r-- | src/video_core/vulkan_common/vulkan_device.cpp | 14 | 
1 files changed, 13 insertions, 1 deletions
| diff --git a/src/video_core/vulkan_common/vulkan_device.cpp b/src/video_core/vulkan_common/vulkan_device.cpp index 40b7ea90f..2caf98c7c 100644 --- a/src/video_core/vulkan_common/vulkan_device.cpp +++ b/src/video_core/vulkan_common/vulkan_device.cpp @@ -243,6 +243,7 @@ Device::Device(VkInstance instance_, vk::PhysicalDevice physical_, VkSurfaceKHR      SetupFamilies(surface);      SetupFeatures();      SetupProperties(); +    CollectTelemetryParameters();      const auto queue_cis = GetDeviceQueueCreateInfos();      const std::vector extensions = LoadExtensions(surface != nullptr); @@ -368,6 +369,18 @@ Device::Device(VkInstance instance_, vk::PhysicalDevice physical_, VkSurfaceKHR      };      SetNext(next, demote); +    if (driver_id == VK_DRIVER_ID_AMD_PROPRIETARY || driver_id == VK_DRIVER_ID_AMD_OPEN_SOURCE) { +        const u32 version = properties.driverVersion; +        // Broken in this driver +        if (version > VK_MAKE_API_VERSION(0, 2, 0, 193)) { +            LOG_WARNING(Render_Vulkan, "AMD proprietary driver versions newer than 21.9.1 " +                                       "(windows) / 0.2.0.194 (amdvlk) have " +                                       "broken VkPhysicalDeviceFloat16Int8FeaturesKHR"); +            is_int8_supported = false; +            is_float16_supported = false; +        } +    } +      if (is_int8_supported || is_float16_supported) {          VkPhysicalDeviceFloat16Int8FeaturesKHR float16_int8{              .sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FLOAT16_INT8_FEATURES_KHR, @@ -560,7 +573,6 @@ Device::Device(VkInstance instance_, vk::PhysicalDevice physical_, VkSurfaceKHR      logical = vk::Device::Create(physical, queue_cis, extensions, first_next, dld);      CollectPhysicalMemoryInfo(); -    CollectTelemetryParameters();      CollectToolingInfo();      if (driver_id == VK_DRIVER_ID_NVIDIA_PROPRIETARY_KHR) { | 
