summaryrefslogtreecommitdiff
path: root/src/video_core/vulkan_common
diff options
context:
space:
mode:
authorGravatar voidanix2022-02-18 09:44:34 +0100
committerGravatar voidanix2022-02-21 09:21:41 +0100
commit7712e46d64e0eb857527cc2592a5373cc7b45e20 (patch)
treea89bc8c3494a3723ab5523de75669cf74095a998 /src/video_core/vulkan_common
parentMerge pull request #7867 from german77/amiibo (diff)
downloadyuzu-7712e46d64e0eb857527cc2592a5373cc7b45e20.tar.gz
yuzu-7712e46d64e0eb857527cc2592a5373cc7b45e20.tar.xz
yuzu-7712e46d64e0eb857527cc2592a5373cc7b45e20.zip
vulkan_device: fix missing format in ANV
Currently Mesa's ANV driver does not support VK_FORMAT_B5G6R5_UNORM_PACK16, implement an alternative for it.
Diffstat (limited to 'src/video_core/vulkan_common')
-rw-r--r--src/video_core/vulkan_common/vulkan_device.cpp12
-rw-r--r--src/video_core/vulkan_common/vulkan_device.h5
2 files changed, 17 insertions, 0 deletions
diff --git a/src/video_core/vulkan_common/vulkan_device.cpp b/src/video_core/vulkan_common/vulkan_device.cpp
index 153702c0b..d0c84215f 100644
--- a/src/video_core/vulkan_common/vulkan_device.cpp
+++ b/src/video_core/vulkan_common/vulkan_device.cpp
@@ -39,6 +39,11 @@ constexpr std::array DEPTH16_UNORM_STENCIL8_UINT{
39 VK_FORMAT_D32_SFLOAT_S8_UINT, 39 VK_FORMAT_D32_SFLOAT_S8_UINT,
40 VK_FORMAT_UNDEFINED, 40 VK_FORMAT_UNDEFINED,
41}; 41};
42
43constexpr std::array B5G6R5_UNORM_PACK16{
44 VK_FORMAT_R5G6B5_UNORM_PACK16,
45 VK_FORMAT_UNDEFINED,
46};
42} // namespace Alternatives 47} // namespace Alternatives
43 48
44enum class NvidiaArchitecture { 49enum class NvidiaArchitecture {
@@ -87,6 +92,8 @@ constexpr const VkFormat* GetFormatAlternatives(VkFormat format) {
87 return Alternatives::DEPTH24_UNORM_STENCIL8_UINT.data(); 92 return Alternatives::DEPTH24_UNORM_STENCIL8_UINT.data();
88 case VK_FORMAT_D16_UNORM_S8_UINT: 93 case VK_FORMAT_D16_UNORM_S8_UINT:
89 return Alternatives::DEPTH16_UNORM_STENCIL8_UINT.data(); 94 return Alternatives::DEPTH16_UNORM_STENCIL8_UINT.data();
95 case VK_FORMAT_B5G6R5_UNORM_PACK16:
96 return Alternatives::B5G6R5_UNORM_PACK16.data();
90 default: 97 default:
91 return nullptr; 98 return nullptr;
92 } 99 }
@@ -639,6 +646,7 @@ Device::Device(VkInstance instance_, vk::PhysicalDevice physical_, VkSurfaceKHR
639 } 646 }
640 647
641 const bool is_intel_windows = driver_id == VK_DRIVER_ID_INTEL_PROPRIETARY_WINDOWS; 648 const bool is_intel_windows = driver_id == VK_DRIVER_ID_INTEL_PROPRIETARY_WINDOWS;
649 const bool is_intel_anv = driver_id == VK_DRIVER_ID_INTEL_OPEN_SOURCE_MESA;
642 if (ext_vertex_input_dynamic_state && is_intel_windows) { 650 if (ext_vertex_input_dynamic_state && is_intel_windows) {
643 LOG_WARNING(Render_Vulkan, "Blacklisting Intel for VK_EXT_vertex_input_dynamic_state"); 651 LOG_WARNING(Render_Vulkan, "Blacklisting Intel for VK_EXT_vertex_input_dynamic_state");
644 ext_vertex_input_dynamic_state = false; 652 ext_vertex_input_dynamic_state = false;
@@ -652,6 +660,10 @@ Device::Device(VkInstance instance_, vk::PhysicalDevice physical_, VkSurfaceKHR
652 LOG_WARNING(Render_Vulkan, "Intel proprietary drivers do not support MSAA image blits"); 660 LOG_WARNING(Render_Vulkan, "Intel proprietary drivers do not support MSAA image blits");
653 cant_blit_msaa = true; 661 cant_blit_msaa = true;
654 } 662 }
663 if (is_intel_anv) {
664 LOG_WARNING(Render_Vulkan, "ANV driver does not support native BGR format");
665 must_emulate_bgr565 = true;
666 }
655 667
656 supports_d24_depth = 668 supports_d24_depth =
657 IsFormatSupported(VK_FORMAT_D24_UNORM_S8_UINT, 669 IsFormatSupported(VK_FORMAT_D24_UNORM_S8_UINT,
diff --git a/src/video_core/vulkan_common/vulkan_device.h b/src/video_core/vulkan_common/vulkan_device.h
index 37d140ebd..34b1add16 100644
--- a/src/video_core/vulkan_common/vulkan_device.h
+++ b/src/video_core/vulkan_common/vulkan_device.h
@@ -354,6 +354,10 @@ public:
354 return cant_blit_msaa; 354 return cant_blit_msaa;
355 } 355 }
356 356
357 bool MustEmulateBGR565() const {
358 return must_emulate_bgr565;
359 }
360
357private: 361private:
358 /// Checks if the physical device is suitable. 362 /// Checks if the physical device is suitable.
359 void CheckSuitability(bool requires_swapchain) const; 363 void CheckSuitability(bool requires_swapchain) const;
@@ -448,6 +452,7 @@ private:
448 bool has_nsight_graphics{}; ///< Has Nsight Graphics attached 452 bool has_nsight_graphics{}; ///< Has Nsight Graphics attached
449 bool supports_d24_depth{}; ///< Supports D24 depth buffers. 453 bool supports_d24_depth{}; ///< Supports D24 depth buffers.
450 bool cant_blit_msaa{}; ///< Does not support MSAA<->MSAA blitting. 454 bool cant_blit_msaa{}; ///< Does not support MSAA<->MSAA blitting.
455 bool must_emulate_bgr565{}; ///< Emulates BGR565 by swizzling RGB565 format.
451 456
452 // Telemetry parameters 457 // Telemetry parameters
453 std::string vendor_name; ///< Device's driver name. 458 std::string vendor_name; ///< Device's driver name.