v3dv: add image view debug checks for VK_KHR_maintenance1
Reviewed-by: Alejandro PiƱeiro <apinheiro@igalia.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/7364>
diff --git a/src/broadcom/vulkan/v3dv_image.c b/src/broadcom/vulkan/v3dv_image.c
index 519d3f1..cf365a1 100644
--- a/src/broadcom/vulkan/v3dv_image.c
+++ b/src/broadcom/vulkan/v3dv_image.c
@@ -327,7 +327,7 @@
image->array_size = pCreateInfo->arrayLayers;
image->samples = pCreateInfo->samples;
image->usage = pCreateInfo->usage;
- image->create_flags = pCreateInfo->flags;
+ image->flags = pCreateInfo->flags;
image->drm_format_mod = modifier;
image->tiling = tiling;
@@ -596,6 +596,13 @@
case VK_IMAGE_TYPE_3D:
assert(range->baseArrayLayer + v3dv_layer_count(image, range) - 1
<= u_minify(image->extent.depth, range->baseMipLevel));
+ /* VK_KHR_maintenance1 */
+ assert(pCreateInfo->viewType != VK_IMAGE_VIEW_TYPE_2D ||
+ ((image->flags & VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT) &&
+ range->levelCount == 1 && range->layerCount == 1));
+ assert(pCreateInfo->viewType != VK_IMAGE_VIEW_TYPE_2D_ARRAY ||
+ ((image->flags & VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT) &&
+ range->levelCount == 1));
break;
default:
unreachable("bad VkImageType");
diff --git a/src/broadcom/vulkan/v3dv_private.h b/src/broadcom/vulkan/v3dv_private.h
index 59e661e..0a916cb 100644
--- a/src/broadcom/vulkan/v3dv_private.h
+++ b/src/broadcom/vulkan/v3dv_private.h
@@ -425,7 +425,7 @@
uint32_t array_size;
uint32_t samples;
VkImageUsageFlags usage;
- VkImageCreateFlags create_flags;
+ VkImageCreateFlags flags;
VkImageTiling tiling;
VkFormat vk_format;