anv: Don't claim support for 24 and 48-bit formats on IVB
authorJason Ekstrand <jason@jlekstrand.net>
Sat, 27 Jul 2019 13:55:47 +0000 (08:55 -0500)
committerJason Ekstrand <jason@jlekstrand.net>
Mon, 29 Jul 2019 16:34:30 +0000 (11:34 -0500)
Cc: mesa-stable@lists.freedesktop.org
src/intel/vulkan/anv_formats.c

index ceb62e345739fe7d2f4f6a1318794e5b7bba8114..2e2fc85105770be053ac0e1b16187b1ba72b3fa5 100644 (file)
@@ -467,6 +467,14 @@ anv_get_format_plane(const struct gen_device_info *devinfo, VkFormat vk_format,
    const struct isl_format_layout *isl_layout =
       isl_format_get_layout(plane_format.isl_format);
 
+   /* On Ivy Bridge we don't even have enough 24 and 48-bit formats that we
+    * can reliably do texture upload with BLORP so just don't claim support
+    * for any of them.
+    */
+   if (devinfo->gen == 7 && !devinfo->is_haswell &&
+       (isl_layout->bpb == 24 || isl_layout->bpb == 48))
+      return unsupported;
+
    if (tiling == VK_IMAGE_TILING_OPTIMAL &&
        !util_is_power_of_two_or_zero(isl_layout->bpb)) {
       /* Tiled formats *must* be power-of-two because we need up upload