diff --git a/src/amd/vulkan/radv_formats.c b/src/amd/vulkan/radv_formats.c index 103d982de0b..7ed01f2aae0 100644 --- a/src/amd/vulkan/radv_formats.c +++ b/src/amd/vulkan/radv_formats.c @@ -1959,6 +1959,10 @@ radv_dcc_formats_compatible(enum amd_gfx_level gfx_level, VkFormat format1, VkFo unsigned size1, size2; int i; + /* All formats are compatible on GFX11. */ + if (gfx_level >= GFX11) + return true; + if (format1 == format2) return true; @@ -1981,16 +1985,8 @@ radv_dcc_formats_compatible(enum amd_gfx_level gfx_level, VkFormat format1, VkFo (type1 == dcc_channel_float) != (type2 == dcc_channel_float) || size1 != size2) return false; - if (type1 != type2) { - /* FIXME: All formats should be compatible on GFX11 but for some reasons DCC with signedness - * reinterpretation doesn't work as expected, like R8_UINT<->R8_SINT. Note that disabling - * fast-clears doesn't help. - */ - if (gfx_level >= GFX11) - return false; - + if (type1 != type2) *sign_reinterpret = true; - } return true; }