xref: /aosp_15_r20/external/mesa3d/src/vulkan/runtime/vk_image.c (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker  * Copyright © 2021 Intel Corporation
3*61046927SAndroid Build Coastguard Worker  *
4*61046927SAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a
5*61046927SAndroid Build Coastguard Worker  * copy of this software and associated documentation files (the "Software"),
6*61046927SAndroid Build Coastguard Worker  * to deal in the Software without restriction, including without limitation
7*61046927SAndroid Build Coastguard Worker  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*61046927SAndroid Build Coastguard Worker  * and/or sell copies of the Software, and to permit persons to whom the
9*61046927SAndroid Build Coastguard Worker  * Software is furnished to do so, subject to the following conditions:
10*61046927SAndroid Build Coastguard Worker  *
11*61046927SAndroid Build Coastguard Worker  * The above copyright notice and this permission notice (including the next
12*61046927SAndroid Build Coastguard Worker  * paragraph) shall be included in all copies or substantial portions of the
13*61046927SAndroid Build Coastguard Worker  * Software.
14*61046927SAndroid Build Coastguard Worker  *
15*61046927SAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*61046927SAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*61046927SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18*61046927SAndroid Build Coastguard Worker  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*61046927SAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20*61046927SAndroid Build Coastguard Worker  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
21*61046927SAndroid Build Coastguard Worker  * IN THE SOFTWARE.
22*61046927SAndroid Build Coastguard Worker  */
23*61046927SAndroid Build Coastguard Worker 
24*61046927SAndroid Build Coastguard Worker #include "vk_image.h"
25*61046927SAndroid Build Coastguard Worker 
26*61046927SAndroid Build Coastguard Worker #if DETECT_OS_LINUX || DETECT_OS_BSD
27*61046927SAndroid Build Coastguard Worker #include <drm-uapi/drm_fourcc.h>
28*61046927SAndroid Build Coastguard Worker #endif
29*61046927SAndroid Build Coastguard Worker 
30*61046927SAndroid Build Coastguard Worker #include "vk_alloc.h"
31*61046927SAndroid Build Coastguard Worker #include "vk_common_entrypoints.h"
32*61046927SAndroid Build Coastguard Worker #include "vk_device.h"
33*61046927SAndroid Build Coastguard Worker #include "vk_format.h"
34*61046927SAndroid Build Coastguard Worker #include "vk_format_info.h"
35*61046927SAndroid Build Coastguard Worker #include "vk_log.h"
36*61046927SAndroid Build Coastguard Worker #include "vk_physical_device.h"
37*61046927SAndroid Build Coastguard Worker #include "vk_render_pass.h"
38*61046927SAndroid Build Coastguard Worker #include "vk_util.h"
39*61046927SAndroid Build Coastguard Worker #include "vulkan/wsi/wsi_common.h"
40*61046927SAndroid Build Coastguard Worker 
41*61046927SAndroid Build Coastguard Worker #if DETECT_OS_ANDROID
42*61046927SAndroid Build Coastguard Worker #include "vk_android.h"
43*61046927SAndroid Build Coastguard Worker #include <vulkan/vulkan_android.h>
44*61046927SAndroid Build Coastguard Worker #endif
45*61046927SAndroid Build Coastguard Worker 
46*61046927SAndroid Build Coastguard Worker void
vk_image_init(struct vk_device * device,struct vk_image * image,const VkImageCreateInfo * pCreateInfo)47*61046927SAndroid Build Coastguard Worker vk_image_init(struct vk_device *device,
48*61046927SAndroid Build Coastguard Worker               struct vk_image *image,
49*61046927SAndroid Build Coastguard Worker               const VkImageCreateInfo *pCreateInfo)
50*61046927SAndroid Build Coastguard Worker {
51*61046927SAndroid Build Coastguard Worker    vk_object_base_init(device, &image->base, VK_OBJECT_TYPE_IMAGE);
52*61046927SAndroid Build Coastguard Worker 
53*61046927SAndroid Build Coastguard Worker    assert(pCreateInfo->sType == VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO);
54*61046927SAndroid Build Coastguard Worker    assert(pCreateInfo->mipLevels > 0);
55*61046927SAndroid Build Coastguard Worker    assert(pCreateInfo->arrayLayers > 0);
56*61046927SAndroid Build Coastguard Worker    assert(pCreateInfo->samples > 0);
57*61046927SAndroid Build Coastguard Worker    assert(pCreateInfo->extent.width > 0);
58*61046927SAndroid Build Coastguard Worker    assert(pCreateInfo->extent.height > 0);
59*61046927SAndroid Build Coastguard Worker    assert(pCreateInfo->extent.depth > 0);
60*61046927SAndroid Build Coastguard Worker 
61*61046927SAndroid Build Coastguard Worker    if (pCreateInfo->flags & VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT)
62*61046927SAndroid Build Coastguard Worker       assert(pCreateInfo->imageType == VK_IMAGE_TYPE_2D);
63*61046927SAndroid Build Coastguard Worker    if (pCreateInfo->flags & VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT)
64*61046927SAndroid Build Coastguard Worker       assert(pCreateInfo->imageType == VK_IMAGE_TYPE_3D);
65*61046927SAndroid Build Coastguard Worker 
66*61046927SAndroid Build Coastguard Worker    image->create_flags = pCreateInfo->flags;
67*61046927SAndroid Build Coastguard Worker    image->image_type = pCreateInfo->imageType;
68*61046927SAndroid Build Coastguard Worker    vk_image_set_format(image, pCreateInfo->format);
69*61046927SAndroid Build Coastguard Worker    image->extent = vk_image_sanitize_extent(image, pCreateInfo->extent);
70*61046927SAndroid Build Coastguard Worker    image->mip_levels = pCreateInfo->mipLevels;
71*61046927SAndroid Build Coastguard Worker    image->array_layers = pCreateInfo->arrayLayers;
72*61046927SAndroid Build Coastguard Worker    image->samples = pCreateInfo->samples;
73*61046927SAndroid Build Coastguard Worker    image->tiling = pCreateInfo->tiling;
74*61046927SAndroid Build Coastguard Worker    image->usage = pCreateInfo->usage;
75*61046927SAndroid Build Coastguard Worker    image->sharing_mode = pCreateInfo->sharingMode;
76*61046927SAndroid Build Coastguard Worker 
77*61046927SAndroid Build Coastguard Worker    if (image->aspects & VK_IMAGE_ASPECT_STENCIL_BIT) {
78*61046927SAndroid Build Coastguard Worker       const VkImageStencilUsageCreateInfo *stencil_usage_info =
79*61046927SAndroid Build Coastguard Worker          vk_find_struct_const(pCreateInfo->pNext,
80*61046927SAndroid Build Coastguard Worker                               IMAGE_STENCIL_USAGE_CREATE_INFO);
81*61046927SAndroid Build Coastguard Worker       image->stencil_usage =
82*61046927SAndroid Build Coastguard Worker          stencil_usage_info ? stencil_usage_info->stencilUsage :
83*61046927SAndroid Build Coastguard Worker                               pCreateInfo->usage;
84*61046927SAndroid Build Coastguard Worker    } else {
85*61046927SAndroid Build Coastguard Worker       image->stencil_usage = 0;
86*61046927SAndroid Build Coastguard Worker    }
87*61046927SAndroid Build Coastguard Worker 
88*61046927SAndroid Build Coastguard Worker    const VkExternalMemoryImageCreateInfo *ext_mem_info =
89*61046927SAndroid Build Coastguard Worker       vk_find_struct_const(pCreateInfo->pNext, EXTERNAL_MEMORY_IMAGE_CREATE_INFO);
90*61046927SAndroid Build Coastguard Worker    if (ext_mem_info)
91*61046927SAndroid Build Coastguard Worker       image->external_handle_types = ext_mem_info->handleTypes;
92*61046927SAndroid Build Coastguard Worker    else
93*61046927SAndroid Build Coastguard Worker       image->external_handle_types = 0;
94*61046927SAndroid Build Coastguard Worker 
95*61046927SAndroid Build Coastguard Worker    const struct wsi_image_create_info *wsi_info =
96*61046927SAndroid Build Coastguard Worker       vk_find_struct_const(pCreateInfo->pNext, WSI_IMAGE_CREATE_INFO_MESA);
97*61046927SAndroid Build Coastguard Worker    image->wsi_legacy_scanout = wsi_info && wsi_info->scanout;
98*61046927SAndroid Build Coastguard Worker 
99*61046927SAndroid Build Coastguard Worker #if DETECT_OS_LINUX || DETECT_OS_BSD
100*61046927SAndroid Build Coastguard Worker    image->drm_format_mod = ((1ULL << 56) - 1) /* DRM_FORMAT_MOD_INVALID */;
101*61046927SAndroid Build Coastguard Worker #endif
102*61046927SAndroid Build Coastguard Worker 
103*61046927SAndroid Build Coastguard Worker #if DETECT_OS_ANDROID
104*61046927SAndroid Build Coastguard Worker    if (image->external_handle_types &
105*61046927SAndroid Build Coastguard Worker              VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID)
106*61046927SAndroid Build Coastguard Worker       image->android_buffer_type = ANDROID_BUFFER_HARDWARE;
107*61046927SAndroid Build Coastguard Worker 
108*61046927SAndroid Build Coastguard Worker    const VkNativeBufferANDROID *native_buffer =
109*61046927SAndroid Build Coastguard Worker       vk_find_struct_const(pCreateInfo->pNext, NATIVE_BUFFER_ANDROID);
110*61046927SAndroid Build Coastguard Worker 
111*61046927SAndroid Build Coastguard Worker    if (native_buffer != NULL) {
112*61046927SAndroid Build Coastguard Worker       assert(image->android_buffer_type == ANDROID_BUFFER_NONE);
113*61046927SAndroid Build Coastguard Worker       image->android_buffer_type = ANDROID_BUFFER_NATIVE;
114*61046927SAndroid Build Coastguard Worker    }
115*61046927SAndroid Build Coastguard Worker 
116*61046927SAndroid Build Coastguard Worker    const VkExternalFormatANDROID *ext_format =
117*61046927SAndroid Build Coastguard Worker       vk_find_struct_const(pCreateInfo->pNext, EXTERNAL_FORMAT_ANDROID);
118*61046927SAndroid Build Coastguard Worker    if (ext_format && ext_format->externalFormat != 0) {
119*61046927SAndroid Build Coastguard Worker       assert(image->format == VK_FORMAT_UNDEFINED);
120*61046927SAndroid Build Coastguard Worker       assert(image->external_handle_types &
121*61046927SAndroid Build Coastguard Worker              VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID);
122*61046927SAndroid Build Coastguard Worker       vk_image_set_format(image, (VkFormat)ext_format->externalFormat);
123*61046927SAndroid Build Coastguard Worker    }
124*61046927SAndroid Build Coastguard Worker 
125*61046927SAndroid Build Coastguard Worker    image->ahb_format = vk_image_format_to_ahb_format(image->format);
126*61046927SAndroid Build Coastguard Worker #endif
127*61046927SAndroid Build Coastguard Worker 
128*61046927SAndroid Build Coastguard Worker    const VkImageCompressionControlEXT *compr_info =
129*61046927SAndroid Build Coastguard Worker       vk_find_struct_const(pCreateInfo->pNext, IMAGE_COMPRESSION_CONTROL_EXT);
130*61046927SAndroid Build Coastguard Worker    if (compr_info)
131*61046927SAndroid Build Coastguard Worker       image->compr_flags = compr_info->flags;
132*61046927SAndroid Build Coastguard Worker }
133*61046927SAndroid Build Coastguard Worker 
134*61046927SAndroid Build Coastguard Worker void *
vk_image_create(struct vk_device * device,const VkImageCreateInfo * pCreateInfo,const VkAllocationCallbacks * alloc,size_t size)135*61046927SAndroid Build Coastguard Worker vk_image_create(struct vk_device *device,
136*61046927SAndroid Build Coastguard Worker                 const VkImageCreateInfo *pCreateInfo,
137*61046927SAndroid Build Coastguard Worker                 const VkAllocationCallbacks *alloc,
138*61046927SAndroid Build Coastguard Worker                 size_t size)
139*61046927SAndroid Build Coastguard Worker {
140*61046927SAndroid Build Coastguard Worker    struct vk_image *image =
141*61046927SAndroid Build Coastguard Worker       vk_zalloc2(&device->alloc, alloc, size, 8,
142*61046927SAndroid Build Coastguard Worker                  VK_SYSTEM_ALLOCATION_SCOPE_OBJECT);
143*61046927SAndroid Build Coastguard Worker    if (image == NULL)
144*61046927SAndroid Build Coastguard Worker       return NULL;
145*61046927SAndroid Build Coastguard Worker 
146*61046927SAndroid Build Coastguard Worker    vk_image_init(device, image, pCreateInfo);
147*61046927SAndroid Build Coastguard Worker 
148*61046927SAndroid Build Coastguard Worker    return image;
149*61046927SAndroid Build Coastguard Worker }
150*61046927SAndroid Build Coastguard Worker 
151*61046927SAndroid Build Coastguard Worker void
vk_image_finish(struct vk_image * image)152*61046927SAndroid Build Coastguard Worker vk_image_finish(struct vk_image *image)
153*61046927SAndroid Build Coastguard Worker {
154*61046927SAndroid Build Coastguard Worker    vk_object_base_finish(&image->base);
155*61046927SAndroid Build Coastguard Worker }
156*61046927SAndroid Build Coastguard Worker 
157*61046927SAndroid Build Coastguard Worker void
vk_image_destroy(struct vk_device * device,const VkAllocationCallbacks * alloc,struct vk_image * image)158*61046927SAndroid Build Coastguard Worker vk_image_destroy(struct vk_device *device,
159*61046927SAndroid Build Coastguard Worker                  const VkAllocationCallbacks *alloc,
160*61046927SAndroid Build Coastguard Worker                  struct vk_image *image)
161*61046927SAndroid Build Coastguard Worker {
162*61046927SAndroid Build Coastguard Worker #if DETECT_OS_ANDROID
163*61046927SAndroid Build Coastguard Worker    if (image->anb_memory) {
164*61046927SAndroid Build Coastguard Worker       device->dispatch_table.FreeMemory(
165*61046927SAndroid Build Coastguard Worker          (VkDevice)device, image->anb_memory, alloc);
166*61046927SAndroid Build Coastguard Worker    }
167*61046927SAndroid Build Coastguard Worker #endif
168*61046927SAndroid Build Coastguard Worker    vk_object_free(device, alloc, image);
169*61046927SAndroid Build Coastguard Worker }
170*61046927SAndroid Build Coastguard Worker 
171*61046927SAndroid Build Coastguard Worker #if DETECT_OS_LINUX || DETECT_OS_BSD
172*61046927SAndroid Build Coastguard Worker VKAPI_ATTR VkResult VKAPI_CALL
vk_common_GetImageDrmFormatModifierPropertiesEXT(UNUSED VkDevice device,VkImage _image,VkImageDrmFormatModifierPropertiesEXT * pProperties)173*61046927SAndroid Build Coastguard Worker vk_common_GetImageDrmFormatModifierPropertiesEXT(UNUSED VkDevice device,
174*61046927SAndroid Build Coastguard Worker                                                  VkImage _image,
175*61046927SAndroid Build Coastguard Worker                                                  VkImageDrmFormatModifierPropertiesEXT *pProperties)
176*61046927SAndroid Build Coastguard Worker {
177*61046927SAndroid Build Coastguard Worker    VK_FROM_HANDLE(vk_image, image, _image);
178*61046927SAndroid Build Coastguard Worker 
179*61046927SAndroid Build Coastguard Worker    assert(pProperties->sType ==
180*61046927SAndroid Build Coastguard Worker           VK_STRUCTURE_TYPE_IMAGE_DRM_FORMAT_MODIFIER_PROPERTIES_EXT);
181*61046927SAndroid Build Coastguard Worker 
182*61046927SAndroid Build Coastguard Worker    assert(image->tiling == VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT);
183*61046927SAndroid Build Coastguard Worker    pProperties->drmFormatModifier = image->drm_format_mod;
184*61046927SAndroid Build Coastguard Worker 
185*61046927SAndroid Build Coastguard Worker    return VK_SUCCESS;
186*61046927SAndroid Build Coastguard Worker }
187*61046927SAndroid Build Coastguard Worker #endif
188*61046927SAndroid Build Coastguard Worker 
189*61046927SAndroid Build Coastguard Worker VKAPI_ATTR void VKAPI_CALL
vk_common_GetImageSubresourceLayout(VkDevice _device,VkImage _image,const VkImageSubresource * pSubresource,VkSubresourceLayout * pLayout)190*61046927SAndroid Build Coastguard Worker vk_common_GetImageSubresourceLayout(VkDevice _device, VkImage _image,
191*61046927SAndroid Build Coastguard Worker                                     const VkImageSubresource *pSubresource,
192*61046927SAndroid Build Coastguard Worker                                     VkSubresourceLayout *pLayout)
193*61046927SAndroid Build Coastguard Worker {
194*61046927SAndroid Build Coastguard Worker    VK_FROM_HANDLE(vk_device, device, _device);
195*61046927SAndroid Build Coastguard Worker 
196*61046927SAndroid Build Coastguard Worker    const VkImageSubresource2KHR subresource = {
197*61046927SAndroid Build Coastguard Worker       .sType = VK_STRUCTURE_TYPE_IMAGE_SUBRESOURCE_2_KHR,
198*61046927SAndroid Build Coastguard Worker       .imageSubresource = *pSubresource,
199*61046927SAndroid Build Coastguard Worker    };
200*61046927SAndroid Build Coastguard Worker 
201*61046927SAndroid Build Coastguard Worker    VkSubresourceLayout2KHR layout = {
202*61046927SAndroid Build Coastguard Worker       .sType = VK_STRUCTURE_TYPE_SUBRESOURCE_LAYOUT_2_KHR
203*61046927SAndroid Build Coastguard Worker    };
204*61046927SAndroid Build Coastguard Worker 
205*61046927SAndroid Build Coastguard Worker    device->dispatch_table.GetImageSubresourceLayout2KHR(_device, _image,
206*61046927SAndroid Build Coastguard Worker                                                         &subresource, &layout);
207*61046927SAndroid Build Coastguard Worker 
208*61046927SAndroid Build Coastguard Worker    *pLayout = layout.subresourceLayout;
209*61046927SAndroid Build Coastguard Worker }
210*61046927SAndroid Build Coastguard Worker 
211*61046927SAndroid Build Coastguard Worker void
vk_image_set_format(struct vk_image * image,VkFormat format)212*61046927SAndroid Build Coastguard Worker vk_image_set_format(struct vk_image *image, VkFormat format)
213*61046927SAndroid Build Coastguard Worker {
214*61046927SAndroid Build Coastguard Worker    image->format = format;
215*61046927SAndroid Build Coastguard Worker    image->aspects = vk_format_aspects(format);
216*61046927SAndroid Build Coastguard Worker }
217*61046927SAndroid Build Coastguard Worker 
218*61046927SAndroid Build Coastguard Worker VkImageUsageFlags
vk_image_usage(const struct vk_image * image,VkImageAspectFlags aspect_mask)219*61046927SAndroid Build Coastguard Worker vk_image_usage(const struct vk_image *image,
220*61046927SAndroid Build Coastguard Worker                VkImageAspectFlags aspect_mask)
221*61046927SAndroid Build Coastguard Worker {
222*61046927SAndroid Build Coastguard Worker    /* From the Vulkan 1.2.131 spec:
223*61046927SAndroid Build Coastguard Worker     *
224*61046927SAndroid Build Coastguard Worker     *    "If the image was has a depth-stencil format and was created with
225*61046927SAndroid Build Coastguard Worker     *    a VkImageStencilUsageCreateInfo structure included in the pNext
226*61046927SAndroid Build Coastguard Worker     *    chain of VkImageCreateInfo, the usage is calculated based on the
227*61046927SAndroid Build Coastguard Worker     *    subresource.aspectMask provided:
228*61046927SAndroid Build Coastguard Worker     *
229*61046927SAndroid Build Coastguard Worker     *     - If aspectMask includes only VK_IMAGE_ASPECT_STENCIL_BIT, the
230*61046927SAndroid Build Coastguard Worker     *       implicit usage is equal to
231*61046927SAndroid Build Coastguard Worker     *       VkImageStencilUsageCreateInfo::stencilUsage.
232*61046927SAndroid Build Coastguard Worker     *
233*61046927SAndroid Build Coastguard Worker     *     - If aspectMask includes only VK_IMAGE_ASPECT_DEPTH_BIT, the
234*61046927SAndroid Build Coastguard Worker     *       implicit usage is equal to VkImageCreateInfo::usage.
235*61046927SAndroid Build Coastguard Worker     *
236*61046927SAndroid Build Coastguard Worker     *     - If both aspects are included in aspectMask, the implicit usage
237*61046927SAndroid Build Coastguard Worker     *       is equal to the intersection of VkImageCreateInfo::usage and
238*61046927SAndroid Build Coastguard Worker     *       VkImageStencilUsageCreateInfo::stencilUsage.
239*61046927SAndroid Build Coastguard Worker     */
240*61046927SAndroid Build Coastguard Worker    if (aspect_mask == VK_IMAGE_ASPECT_STENCIL_BIT) {
241*61046927SAndroid Build Coastguard Worker       return image->stencil_usage;
242*61046927SAndroid Build Coastguard Worker    } else if (aspect_mask == (VK_IMAGE_ASPECT_DEPTH_BIT |
243*61046927SAndroid Build Coastguard Worker                               VK_IMAGE_ASPECT_STENCIL_BIT)) {
244*61046927SAndroid Build Coastguard Worker       return image->usage & image->stencil_usage;
245*61046927SAndroid Build Coastguard Worker    } else {
246*61046927SAndroid Build Coastguard Worker       /* This also handles the color case */
247*61046927SAndroid Build Coastguard Worker       return image->usage;
248*61046927SAndroid Build Coastguard Worker    }
249*61046927SAndroid Build Coastguard Worker }
250*61046927SAndroid Build Coastguard Worker 
251*61046927SAndroid Build Coastguard Worker #define VK_IMAGE_ASPECT_ANY_COLOR_MASK_MESA ( \
252*61046927SAndroid Build Coastguard Worker    VK_IMAGE_ASPECT_COLOR_BIT | \
253*61046927SAndroid Build Coastguard Worker    VK_IMAGE_ASPECT_PLANE_0_BIT | \
254*61046927SAndroid Build Coastguard Worker    VK_IMAGE_ASPECT_PLANE_1_BIT | \
255*61046927SAndroid Build Coastguard Worker    VK_IMAGE_ASPECT_PLANE_2_BIT)
256*61046927SAndroid Build Coastguard Worker 
257*61046927SAndroid Build Coastguard Worker /** Expands the given aspect mask relative to the image
258*61046927SAndroid Build Coastguard Worker  *
259*61046927SAndroid Build Coastguard Worker  * If the image has color plane aspects VK_IMAGE_ASPECT_COLOR_BIT has been
260*61046927SAndroid Build Coastguard Worker  * requested, this returns the aspects of the underlying image.
261*61046927SAndroid Build Coastguard Worker  *
262*61046927SAndroid Build Coastguard Worker  * For example,
263*61046927SAndroid Build Coastguard Worker  *
264*61046927SAndroid Build Coastguard Worker  *    VK_IMAGE_ASPECT_COLOR_BIT
265*61046927SAndroid Build Coastguard Worker  *
266*61046927SAndroid Build Coastguard Worker  * will be converted to
267*61046927SAndroid Build Coastguard Worker  *
268*61046927SAndroid Build Coastguard Worker  *    VK_IMAGE_ASPECT_PLANE_0_BIT |
269*61046927SAndroid Build Coastguard Worker  *    VK_IMAGE_ASPECT_PLANE_1_BIT |
270*61046927SAndroid Build Coastguard Worker  *    VK_IMAGE_ASPECT_PLANE_2_BIT
271*61046927SAndroid Build Coastguard Worker  *
272*61046927SAndroid Build Coastguard Worker  * for an image of format VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM.
273*61046927SAndroid Build Coastguard Worker  */
274*61046927SAndroid Build Coastguard Worker VkImageAspectFlags
vk_image_expand_aspect_mask(const struct vk_image * image,VkImageAspectFlags aspect_mask)275*61046927SAndroid Build Coastguard Worker vk_image_expand_aspect_mask(const struct vk_image *image,
276*61046927SAndroid Build Coastguard Worker                             VkImageAspectFlags aspect_mask)
277*61046927SAndroid Build Coastguard Worker {
278*61046927SAndroid Build Coastguard Worker    if (aspect_mask == VK_IMAGE_ASPECT_COLOR_BIT) {
279*61046927SAndroid Build Coastguard Worker       assert(image->aspects & VK_IMAGE_ASPECT_ANY_COLOR_MASK_MESA);
280*61046927SAndroid Build Coastguard Worker       return image->aspects;
281*61046927SAndroid Build Coastguard Worker    } else {
282*61046927SAndroid Build Coastguard Worker       assert(aspect_mask && !(aspect_mask & ~image->aspects));
283*61046927SAndroid Build Coastguard Worker       return aspect_mask;
284*61046927SAndroid Build Coastguard Worker    }
285*61046927SAndroid Build Coastguard Worker }
286*61046927SAndroid Build Coastguard Worker 
287*61046927SAndroid Build Coastguard Worker VkExtent3D
vk_image_extent_to_elements(const struct vk_image * image,VkExtent3D extent)288*61046927SAndroid Build Coastguard Worker vk_image_extent_to_elements(const struct vk_image *image, VkExtent3D extent)
289*61046927SAndroid Build Coastguard Worker {
290*61046927SAndroid Build Coastguard Worker    const struct util_format_description *fmt =
291*61046927SAndroid Build Coastguard Worker       vk_format_description(image->format);
292*61046927SAndroid Build Coastguard Worker 
293*61046927SAndroid Build Coastguard Worker    extent = vk_image_sanitize_extent(image, extent);
294*61046927SAndroid Build Coastguard Worker    extent.width = DIV_ROUND_UP(extent.width, fmt->block.width);
295*61046927SAndroid Build Coastguard Worker    extent.height = DIV_ROUND_UP(extent.height, fmt->block.height);
296*61046927SAndroid Build Coastguard Worker    extent.depth = DIV_ROUND_UP(extent.depth, fmt->block.depth);
297*61046927SAndroid Build Coastguard Worker 
298*61046927SAndroid Build Coastguard Worker    return extent;
299*61046927SAndroid Build Coastguard Worker }
300*61046927SAndroid Build Coastguard Worker 
301*61046927SAndroid Build Coastguard Worker VkOffset3D
vk_image_offset_to_elements(const struct vk_image * image,VkOffset3D offset)302*61046927SAndroid Build Coastguard Worker vk_image_offset_to_elements(const struct vk_image *image, VkOffset3D offset)
303*61046927SAndroid Build Coastguard Worker {
304*61046927SAndroid Build Coastguard Worker    const struct util_format_description *fmt =
305*61046927SAndroid Build Coastguard Worker       vk_format_description(image->format);
306*61046927SAndroid Build Coastguard Worker 
307*61046927SAndroid Build Coastguard Worker    offset = vk_image_sanitize_offset(image, offset);
308*61046927SAndroid Build Coastguard Worker 
309*61046927SAndroid Build Coastguard Worker    assert(offset.x % fmt->block.width == 0);
310*61046927SAndroid Build Coastguard Worker    assert(offset.y % fmt->block.height == 0);
311*61046927SAndroid Build Coastguard Worker    assert(offset.z % fmt->block.depth == 0);
312*61046927SAndroid Build Coastguard Worker 
313*61046927SAndroid Build Coastguard Worker    offset.x /= fmt->block.width;
314*61046927SAndroid Build Coastguard Worker    offset.y /= fmt->block.height;
315*61046927SAndroid Build Coastguard Worker    offset.z /= fmt->block.depth;
316*61046927SAndroid Build Coastguard Worker 
317*61046927SAndroid Build Coastguard Worker    return offset;
318*61046927SAndroid Build Coastguard Worker }
319*61046927SAndroid Build Coastguard Worker 
320*61046927SAndroid Build Coastguard Worker struct vk_image_buffer_layout
vk_image_buffer_copy_layout(const struct vk_image * image,const VkBufferImageCopy2 * region)321*61046927SAndroid Build Coastguard Worker vk_image_buffer_copy_layout(const struct vk_image *image,
322*61046927SAndroid Build Coastguard Worker                             const VkBufferImageCopy2* region)
323*61046927SAndroid Build Coastguard Worker {
324*61046927SAndroid Build Coastguard Worker    VkExtent3D extent = vk_image_sanitize_extent(image, region->imageExtent);
325*61046927SAndroid Build Coastguard Worker 
326*61046927SAndroid Build Coastguard Worker    const uint32_t row_length = region->bufferRowLength ?
327*61046927SAndroid Build Coastguard Worker                                region->bufferRowLength : extent.width;
328*61046927SAndroid Build Coastguard Worker    const uint32_t image_height = region->bufferImageHeight ?
329*61046927SAndroid Build Coastguard Worker                                  region->bufferImageHeight : extent.height;
330*61046927SAndroid Build Coastguard Worker 
331*61046927SAndroid Build Coastguard Worker    const VkImageAspectFlags aspect = region->imageSubresource.aspectMask;
332*61046927SAndroid Build Coastguard Worker    VkFormat format = vk_format_get_aspect_format(image->format, aspect);
333*61046927SAndroid Build Coastguard Worker    const struct util_format_description *fmt = vk_format_description(format);
334*61046927SAndroid Build Coastguard Worker 
335*61046927SAndroid Build Coastguard Worker    assert(fmt->block.bits % 8 == 0);
336*61046927SAndroid Build Coastguard Worker    const uint32_t element_size_B = fmt->block.bits / 8;
337*61046927SAndroid Build Coastguard Worker 
338*61046927SAndroid Build Coastguard Worker    const uint32_t row_stride_B =
339*61046927SAndroid Build Coastguard Worker       DIV_ROUND_UP(row_length, fmt->block.width) * element_size_B;
340*61046927SAndroid Build Coastguard Worker    const uint64_t image_stride_B =
341*61046927SAndroid Build Coastguard Worker       DIV_ROUND_UP(image_height, fmt->block.height) * (uint64_t)row_stride_B;
342*61046927SAndroid Build Coastguard Worker 
343*61046927SAndroid Build Coastguard Worker    return (struct vk_image_buffer_layout) {
344*61046927SAndroid Build Coastguard Worker       .row_length = row_length,
345*61046927SAndroid Build Coastguard Worker       .image_height = image_height,
346*61046927SAndroid Build Coastguard Worker       .element_size_B = element_size_B,
347*61046927SAndroid Build Coastguard Worker       .row_stride_B = row_stride_B,
348*61046927SAndroid Build Coastguard Worker       .image_stride_B = image_stride_B,
349*61046927SAndroid Build Coastguard Worker    };
350*61046927SAndroid Build Coastguard Worker }
351*61046927SAndroid Build Coastguard Worker 
352*61046927SAndroid Build Coastguard Worker struct vk_image_buffer_layout
vk_memory_to_image_copy_layout(const struct vk_image * image,const VkMemoryToImageCopyEXT * region)353*61046927SAndroid Build Coastguard Worker vk_memory_to_image_copy_layout(const struct vk_image *image,
354*61046927SAndroid Build Coastguard Worker                                const VkMemoryToImageCopyEXT* region)
355*61046927SAndroid Build Coastguard Worker {
356*61046927SAndroid Build Coastguard Worker    const VkBufferImageCopy2 bic = {
357*61046927SAndroid Build Coastguard Worker       .bufferOffset = 0,
358*61046927SAndroid Build Coastguard Worker       .bufferRowLength = region->memoryRowLength,
359*61046927SAndroid Build Coastguard Worker       .bufferImageHeight = region->memoryImageHeight,
360*61046927SAndroid Build Coastguard Worker       .imageSubresource = region->imageSubresource,
361*61046927SAndroid Build Coastguard Worker       .imageOffset = region->imageOffset,
362*61046927SAndroid Build Coastguard Worker       .imageExtent = region->imageExtent,
363*61046927SAndroid Build Coastguard Worker    };
364*61046927SAndroid Build Coastguard Worker    return vk_image_buffer_copy_layout(image, &bic);
365*61046927SAndroid Build Coastguard Worker }
366*61046927SAndroid Build Coastguard Worker 
367*61046927SAndroid Build Coastguard Worker struct vk_image_buffer_layout
vk_image_to_memory_copy_layout(const struct vk_image * image,const VkImageToMemoryCopyEXT * region)368*61046927SAndroid Build Coastguard Worker vk_image_to_memory_copy_layout(const struct vk_image *image,
369*61046927SAndroid Build Coastguard Worker                                const VkImageToMemoryCopyEXT* region)
370*61046927SAndroid Build Coastguard Worker {
371*61046927SAndroid Build Coastguard Worker    const VkBufferImageCopy2 bic = {
372*61046927SAndroid Build Coastguard Worker       .bufferOffset = 0,
373*61046927SAndroid Build Coastguard Worker       .bufferRowLength = region->memoryRowLength,
374*61046927SAndroid Build Coastguard Worker       .bufferImageHeight = region->memoryImageHeight,
375*61046927SAndroid Build Coastguard Worker       .imageSubresource = region->imageSubresource,
376*61046927SAndroid Build Coastguard Worker       .imageOffset = region->imageOffset,
377*61046927SAndroid Build Coastguard Worker       .imageExtent = region->imageExtent,
378*61046927SAndroid Build Coastguard Worker    };
379*61046927SAndroid Build Coastguard Worker    return vk_image_buffer_copy_layout(image, &bic);
380*61046927SAndroid Build Coastguard Worker }
381*61046927SAndroid Build Coastguard Worker 
382*61046927SAndroid Build Coastguard Worker static VkComponentSwizzle
remap_swizzle(VkComponentSwizzle swizzle,VkComponentSwizzle component)383*61046927SAndroid Build Coastguard Worker remap_swizzle(VkComponentSwizzle swizzle, VkComponentSwizzle component)
384*61046927SAndroid Build Coastguard Worker {
385*61046927SAndroid Build Coastguard Worker    return swizzle == VK_COMPONENT_SWIZZLE_IDENTITY ? component : swizzle;
386*61046927SAndroid Build Coastguard Worker }
387*61046927SAndroid Build Coastguard Worker 
388*61046927SAndroid Build Coastguard Worker void
vk_image_view_init(struct vk_device * device,struct vk_image_view * image_view,bool driver_internal,const VkImageViewCreateInfo * pCreateInfo)389*61046927SAndroid Build Coastguard Worker vk_image_view_init(struct vk_device *device,
390*61046927SAndroid Build Coastguard Worker                    struct vk_image_view *image_view,
391*61046927SAndroid Build Coastguard Worker                    bool driver_internal,
392*61046927SAndroid Build Coastguard Worker                    const VkImageViewCreateInfo *pCreateInfo)
393*61046927SAndroid Build Coastguard Worker {
394*61046927SAndroid Build Coastguard Worker    vk_object_base_init(device, &image_view->base, VK_OBJECT_TYPE_IMAGE_VIEW);
395*61046927SAndroid Build Coastguard Worker 
396*61046927SAndroid Build Coastguard Worker    assert(pCreateInfo->sType == VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO);
397*61046927SAndroid Build Coastguard Worker    VK_FROM_HANDLE(vk_image, image, pCreateInfo->image);
398*61046927SAndroid Build Coastguard Worker 
399*61046927SAndroid Build Coastguard Worker    image_view->create_flags = pCreateInfo->flags;
400*61046927SAndroid Build Coastguard Worker    image_view->image = image;
401*61046927SAndroid Build Coastguard Worker    image_view->view_type = pCreateInfo->viewType;
402*61046927SAndroid Build Coastguard Worker 
403*61046927SAndroid Build Coastguard Worker    image_view->format = pCreateInfo->format;
404*61046927SAndroid Build Coastguard Worker    if (image_view->format == VK_FORMAT_UNDEFINED)
405*61046927SAndroid Build Coastguard Worker       image_view->format = image->format;
406*61046927SAndroid Build Coastguard Worker 
407*61046927SAndroid Build Coastguard Worker    if (!driver_internal) {
408*61046927SAndroid Build Coastguard Worker       switch (image_view->view_type) {
409*61046927SAndroid Build Coastguard Worker       case VK_IMAGE_VIEW_TYPE_1D:
410*61046927SAndroid Build Coastguard Worker       case VK_IMAGE_VIEW_TYPE_1D_ARRAY:
411*61046927SAndroid Build Coastguard Worker          assert(image->image_type == VK_IMAGE_TYPE_1D);
412*61046927SAndroid Build Coastguard Worker          break;
413*61046927SAndroid Build Coastguard Worker       case VK_IMAGE_VIEW_TYPE_2D:
414*61046927SAndroid Build Coastguard Worker       case VK_IMAGE_VIEW_TYPE_2D_ARRAY:
415*61046927SAndroid Build Coastguard Worker          if (image->create_flags & (VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT |
416*61046927SAndroid Build Coastguard Worker                                     VK_IMAGE_CREATE_2D_VIEW_COMPATIBLE_BIT_EXT))
417*61046927SAndroid Build Coastguard Worker             assert(image->image_type == VK_IMAGE_TYPE_3D);
418*61046927SAndroid Build Coastguard Worker          else
419*61046927SAndroid Build Coastguard Worker             assert(image->image_type == VK_IMAGE_TYPE_2D);
420*61046927SAndroid Build Coastguard Worker          break;
421*61046927SAndroid Build Coastguard Worker       case VK_IMAGE_VIEW_TYPE_3D:
422*61046927SAndroid Build Coastguard Worker          assert(image->image_type == VK_IMAGE_TYPE_3D);
423*61046927SAndroid Build Coastguard Worker          break;
424*61046927SAndroid Build Coastguard Worker       case VK_IMAGE_VIEW_TYPE_CUBE:
425*61046927SAndroid Build Coastguard Worker       case VK_IMAGE_VIEW_TYPE_CUBE_ARRAY:
426*61046927SAndroid Build Coastguard Worker          assert(image->image_type == VK_IMAGE_TYPE_2D);
427*61046927SAndroid Build Coastguard Worker          assert(image->create_flags & VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT);
428*61046927SAndroid Build Coastguard Worker          break;
429*61046927SAndroid Build Coastguard Worker       default:
430*61046927SAndroid Build Coastguard Worker          unreachable("Invalid image view type");
431*61046927SAndroid Build Coastguard Worker       }
432*61046927SAndroid Build Coastguard Worker    }
433*61046927SAndroid Build Coastguard Worker 
434*61046927SAndroid Build Coastguard Worker    const VkImageSubresourceRange *range = &pCreateInfo->subresourceRange;
435*61046927SAndroid Build Coastguard Worker 
436*61046927SAndroid Build Coastguard Worker    if (driver_internal) {
437*61046927SAndroid Build Coastguard Worker       image_view->aspects = range->aspectMask;
438*61046927SAndroid Build Coastguard Worker       image_view->view_format = image_view->format;
439*61046927SAndroid Build Coastguard Worker    } else {
440*61046927SAndroid Build Coastguard Worker       image_view->aspects =
441*61046927SAndroid Build Coastguard Worker          vk_image_expand_aspect_mask(image, range->aspectMask);
442*61046927SAndroid Build Coastguard Worker 
443*61046927SAndroid Build Coastguard Worker       assert(!(image_view->aspects & ~image->aspects));
444*61046927SAndroid Build Coastguard Worker 
445*61046927SAndroid Build Coastguard Worker       /* From the Vulkan 1.2.184 spec:
446*61046927SAndroid Build Coastguard Worker        *
447*61046927SAndroid Build Coastguard Worker        *    "If the image has a multi-planar format and
448*61046927SAndroid Build Coastguard Worker        *    subresourceRange.aspectMask is VK_IMAGE_ASPECT_COLOR_BIT, and image
449*61046927SAndroid Build Coastguard Worker        *    has been created with a usage value not containing any of the
450*61046927SAndroid Build Coastguard Worker        *    VK_IMAGE_USAGE_VIDEO_DECODE_DST_BIT_KHR,
451*61046927SAndroid Build Coastguard Worker        *    VK_IMAGE_USAGE_VIDEO_DECODE_SRC_BIT_KHR,
452*61046927SAndroid Build Coastguard Worker        *    VK_IMAGE_USAGE_VIDEO_DECODE_DPB_BIT_KHR,
453*61046927SAndroid Build Coastguard Worker        *    VK_IMAGE_USAGE_VIDEO_ENCODE_DST_BIT_KHR,
454*61046927SAndroid Build Coastguard Worker        *    VK_IMAGE_USAGE_VIDEO_ENCODE_SRC_BIT_KHR, and
455*61046927SAndroid Build Coastguard Worker        *    VK_IMAGE_USAGE_VIDEO_ENCODE_DPB_BIT_KHR flags, then the format must
456*61046927SAndroid Build Coastguard Worker        *    be identical to the image format, and the sampler to be used with the
457*61046927SAndroid Build Coastguard Worker        *    image view must enable sampler Y′CBCR conversion."
458*61046927SAndroid Build Coastguard Worker        *
459*61046927SAndroid Build Coastguard Worker        * Since no one implements video yet, we can ignore the bits about video
460*61046927SAndroid Build Coastguard Worker        * create flags and assume YCbCr formats match.
461*61046927SAndroid Build Coastguard Worker        */
462*61046927SAndroid Build Coastguard Worker       if ((image->aspects & VK_IMAGE_ASPECT_PLANE_1_BIT) &&
463*61046927SAndroid Build Coastguard Worker           (range->aspectMask == VK_IMAGE_ASPECT_COLOR_BIT))
464*61046927SAndroid Build Coastguard Worker          assert(image_view->format == image->format);
465*61046927SAndroid Build Coastguard Worker 
466*61046927SAndroid Build Coastguard Worker       /* From the Vulkan 1.2.184 spec:
467*61046927SAndroid Build Coastguard Worker        *
468*61046927SAndroid Build Coastguard Worker        *    "Each depth/stencil format is only compatible with itself."
469*61046927SAndroid Build Coastguard Worker        */
470*61046927SAndroid Build Coastguard Worker       if (image_view->aspects & (VK_IMAGE_ASPECT_DEPTH_BIT |
471*61046927SAndroid Build Coastguard Worker                                  VK_IMAGE_ASPECT_STENCIL_BIT))
472*61046927SAndroid Build Coastguard Worker          assert(image_view->format == image->format);
473*61046927SAndroid Build Coastguard Worker 
474*61046927SAndroid Build Coastguard Worker       if (!(image->create_flags & VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT))
475*61046927SAndroid Build Coastguard Worker          assert(image_view->format == image->format);
476*61046927SAndroid Build Coastguard Worker 
477*61046927SAndroid Build Coastguard Worker       /* Restrict the format to only the planes chosen.
478*61046927SAndroid Build Coastguard Worker        *
479*61046927SAndroid Build Coastguard Worker        * For combined depth and stencil images, this means the depth-only or
480*61046927SAndroid Build Coastguard Worker        * stencil-only format if only one aspect is chosen and the full
481*61046927SAndroid Build Coastguard Worker        * combined format if both aspects are chosen.
482*61046927SAndroid Build Coastguard Worker        *
483*61046927SAndroid Build Coastguard Worker        * For single-plane color images, we just take the format as-is.  For
484*61046927SAndroid Build Coastguard Worker        * multi-plane views of multi-plane images, this means we want the full
485*61046927SAndroid Build Coastguard Worker        * multi-plane format.  For single-plane views of multi-plane images, we
486*61046927SAndroid Build Coastguard Worker        * want a format compatible with the one plane.  Fortunately, this is
487*61046927SAndroid Build Coastguard Worker        * already what the client gives us.  The Vulkan 1.2.184 spec says:
488*61046927SAndroid Build Coastguard Worker        *
489*61046927SAndroid Build Coastguard Worker        *    "If image was created with the VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT
490*61046927SAndroid Build Coastguard Worker        *    and the image has a multi-planar format, and if
491*61046927SAndroid Build Coastguard Worker        *    subresourceRange.aspectMask is VK_IMAGE_ASPECT_PLANE_0_BIT,
492*61046927SAndroid Build Coastguard Worker        *    VK_IMAGE_ASPECT_PLANE_1_BIT, or VK_IMAGE_ASPECT_PLANE_2_BIT,
493*61046927SAndroid Build Coastguard Worker        *    format must be compatible with the corresponding plane of the
494*61046927SAndroid Build Coastguard Worker        *    image, and the sampler to be used with the image view must not
495*61046927SAndroid Build Coastguard Worker        *    enable sampler Y′CBCR conversion."
496*61046927SAndroid Build Coastguard Worker        */
497*61046927SAndroid Build Coastguard Worker       if (image_view->aspects == VK_IMAGE_ASPECT_STENCIL_BIT) {
498*61046927SAndroid Build Coastguard Worker          image_view->view_format = vk_format_stencil_only(image_view->format);
499*61046927SAndroid Build Coastguard Worker       } else if (image_view->aspects == VK_IMAGE_ASPECT_DEPTH_BIT) {
500*61046927SAndroid Build Coastguard Worker          image_view->view_format = vk_format_depth_only(image_view->format);
501*61046927SAndroid Build Coastguard Worker       } else {
502*61046927SAndroid Build Coastguard Worker          image_view->view_format = image_view->format;
503*61046927SAndroid Build Coastguard Worker       }
504*61046927SAndroid Build Coastguard Worker    }
505*61046927SAndroid Build Coastguard Worker 
506*61046927SAndroid Build Coastguard Worker    image_view->swizzle = (VkComponentMapping) {
507*61046927SAndroid Build Coastguard Worker       .r = remap_swizzle(pCreateInfo->components.r, VK_COMPONENT_SWIZZLE_R),
508*61046927SAndroid Build Coastguard Worker       .g = remap_swizzle(pCreateInfo->components.g, VK_COMPONENT_SWIZZLE_G),
509*61046927SAndroid Build Coastguard Worker       .b = remap_swizzle(pCreateInfo->components.b, VK_COMPONENT_SWIZZLE_B),
510*61046927SAndroid Build Coastguard Worker       .a = remap_swizzle(pCreateInfo->components.a, VK_COMPONENT_SWIZZLE_A),
511*61046927SAndroid Build Coastguard Worker    };
512*61046927SAndroid Build Coastguard Worker 
513*61046927SAndroid Build Coastguard Worker    assert(range->layerCount > 0);
514*61046927SAndroid Build Coastguard Worker    assert(range->baseMipLevel < image->mip_levels);
515*61046927SAndroid Build Coastguard Worker 
516*61046927SAndroid Build Coastguard Worker    image_view->base_mip_level = range->baseMipLevel;
517*61046927SAndroid Build Coastguard Worker    image_view->level_count = vk_image_subresource_level_count(image, range);
518*61046927SAndroid Build Coastguard Worker    image_view->base_array_layer = range->baseArrayLayer;
519*61046927SAndroid Build Coastguard Worker    image_view->layer_count = vk_image_subresource_layer_count(image, range);
520*61046927SAndroid Build Coastguard Worker 
521*61046927SAndroid Build Coastguard Worker    const VkImageViewMinLodCreateInfoEXT *min_lod_info =
522*61046927SAndroid Build Coastguard Worker       vk_find_struct_const(pCreateInfo, IMAGE_VIEW_MIN_LOD_CREATE_INFO_EXT);
523*61046927SAndroid Build Coastguard Worker    image_view->min_lod = min_lod_info ? min_lod_info->minLod : 0.0f;
524*61046927SAndroid Build Coastguard Worker 
525*61046927SAndroid Build Coastguard Worker    /* From the Vulkan 1.3.215 spec:
526*61046927SAndroid Build Coastguard Worker     *
527*61046927SAndroid Build Coastguard Worker     *    VUID-VkImageViewMinLodCreateInfoEXT-minLod-06456
528*61046927SAndroid Build Coastguard Worker     *
529*61046927SAndroid Build Coastguard Worker     *    "minLod must be less or equal to the index of the last mipmap level
530*61046927SAndroid Build Coastguard Worker     *    accessible to the view."
531*61046927SAndroid Build Coastguard Worker     */
532*61046927SAndroid Build Coastguard Worker    assert(image_view->min_lod <= image_view->base_mip_level +
533*61046927SAndroid Build Coastguard Worker                                  image_view->level_count - 1);
534*61046927SAndroid Build Coastguard Worker 
535*61046927SAndroid Build Coastguard Worker    image_view->extent =
536*61046927SAndroid Build Coastguard Worker       vk_image_mip_level_extent(image, image_view->base_mip_level);
537*61046927SAndroid Build Coastguard Worker 
538*61046927SAndroid Build Coastguard Worker    if (vk_format_is_compressed(image->format) &&
539*61046927SAndroid Build Coastguard Worker        !vk_format_is_compressed(image_view->format)) {
540*61046927SAndroid Build Coastguard Worker       const struct util_format_description *fmt =
541*61046927SAndroid Build Coastguard Worker          vk_format_description(image_view->format);
542*61046927SAndroid Build Coastguard Worker 
543*61046927SAndroid Build Coastguard Worker       /* Non-compressed view of compressed image only works for single MIP
544*61046927SAndroid Build Coastguard Worker        * views.
545*61046927SAndroid Build Coastguard Worker        */
546*61046927SAndroid Build Coastguard Worker       assert(image_view->level_count == 1);
547*61046927SAndroid Build Coastguard Worker       image_view->extent.width =
548*61046927SAndroid Build Coastguard Worker          DIV_ROUND_UP(image_view->extent.width, fmt->block.width);
549*61046927SAndroid Build Coastguard Worker       image_view->extent.height =
550*61046927SAndroid Build Coastguard Worker          DIV_ROUND_UP(image_view->extent.height, fmt->block.height);
551*61046927SAndroid Build Coastguard Worker       image_view->extent.depth =
552*61046927SAndroid Build Coastguard Worker          DIV_ROUND_UP(image_view->extent.depth, fmt->block.depth);
553*61046927SAndroid Build Coastguard Worker    }
554*61046927SAndroid Build Coastguard Worker 
555*61046927SAndroid Build Coastguard Worker    /* By default storage uses the same as the image properties, but it can be
556*61046927SAndroid Build Coastguard Worker     * overriden with VkImageViewSlicedCreateInfoEXT.
557*61046927SAndroid Build Coastguard Worker     */
558*61046927SAndroid Build Coastguard Worker    image_view->storage.z_slice_offset = 0;
559*61046927SAndroid Build Coastguard Worker    image_view->storage.z_slice_count = image_view->extent.depth;
560*61046927SAndroid Build Coastguard Worker 
561*61046927SAndroid Build Coastguard Worker    const VkImageViewSlicedCreateInfoEXT *sliced_info =
562*61046927SAndroid Build Coastguard Worker       vk_find_struct_const(pCreateInfo, IMAGE_VIEW_SLICED_CREATE_INFO_EXT);
563*61046927SAndroid Build Coastguard Worker    assert(image_view->base_mip_level + image_view->level_count
564*61046927SAndroid Build Coastguard Worker           <= image->mip_levels);
565*61046927SAndroid Build Coastguard Worker    switch (image->image_type) {
566*61046927SAndroid Build Coastguard Worker    default:
567*61046927SAndroid Build Coastguard Worker       unreachable("bad VkImageType");
568*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_TYPE_1D:
569*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_TYPE_2D:
570*61046927SAndroid Build Coastguard Worker       assert(image_view->base_array_layer + image_view->layer_count
571*61046927SAndroid Build Coastguard Worker              <= image->array_layers);
572*61046927SAndroid Build Coastguard Worker       break;
573*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_TYPE_3D:
574*61046927SAndroid Build Coastguard Worker       if (sliced_info && image_view->view_type == VK_IMAGE_VIEW_TYPE_3D) {
575*61046927SAndroid Build Coastguard Worker          unsigned total = image_view->extent.depth;
576*61046927SAndroid Build Coastguard Worker          image_view->storage.z_slice_offset = sliced_info->sliceOffset;
577*61046927SAndroid Build Coastguard Worker          assert(image_view->storage.z_slice_offset < total);
578*61046927SAndroid Build Coastguard Worker          if (sliced_info->sliceCount == VK_REMAINING_3D_SLICES_EXT) {
579*61046927SAndroid Build Coastguard Worker             image_view->storage.z_slice_count = total - image_view->storage.z_slice_offset;
580*61046927SAndroid Build Coastguard Worker          } else {
581*61046927SAndroid Build Coastguard Worker             image_view->storage.z_slice_count = sliced_info->sliceCount;
582*61046927SAndroid Build Coastguard Worker          }
583*61046927SAndroid Build Coastguard Worker       } else if (image_view->view_type != VK_IMAGE_VIEW_TYPE_3D) {
584*61046927SAndroid Build Coastguard Worker          image_view->storage.z_slice_offset = image_view->base_array_layer;
585*61046927SAndroid Build Coastguard Worker          image_view->storage.z_slice_count = image_view->layer_count;
586*61046927SAndroid Build Coastguard Worker       }
587*61046927SAndroid Build Coastguard Worker       assert(image_view->storage.z_slice_offset + image_view->storage.z_slice_count
588*61046927SAndroid Build Coastguard Worker              <= image->extent.depth);
589*61046927SAndroid Build Coastguard Worker       assert(image_view->base_array_layer + image_view->layer_count
590*61046927SAndroid Build Coastguard Worker              <= image_view->extent.depth);
591*61046927SAndroid Build Coastguard Worker       break;
592*61046927SAndroid Build Coastguard Worker    }
593*61046927SAndroid Build Coastguard Worker 
594*61046927SAndroid Build Coastguard Worker    /* If we are creating a color view from a depth/stencil image we compute
595*61046927SAndroid Build Coastguard Worker     * usage from the underlying depth/stencil aspects.
596*61046927SAndroid Build Coastguard Worker     */
597*61046927SAndroid Build Coastguard Worker    const VkImageUsageFlags image_usage =
598*61046927SAndroid Build Coastguard Worker       vk_image_usage(image, image_view->aspects);
599*61046927SAndroid Build Coastguard Worker    const VkImageViewUsageCreateInfo *usage_info =
600*61046927SAndroid Build Coastguard Worker       vk_find_struct_const(pCreateInfo, IMAGE_VIEW_USAGE_CREATE_INFO);
601*61046927SAndroid Build Coastguard Worker    image_view->usage = usage_info ? usage_info->usage : image_usage;
602*61046927SAndroid Build Coastguard Worker    assert(driver_internal || !(image_view->usage & ~image_usage));
603*61046927SAndroid Build Coastguard Worker }
604*61046927SAndroid Build Coastguard Worker 
605*61046927SAndroid Build Coastguard Worker void
vk_image_view_finish(struct vk_image_view * image_view)606*61046927SAndroid Build Coastguard Worker vk_image_view_finish(struct vk_image_view *image_view)
607*61046927SAndroid Build Coastguard Worker {
608*61046927SAndroid Build Coastguard Worker    vk_object_base_finish(&image_view->base);
609*61046927SAndroid Build Coastguard Worker }
610*61046927SAndroid Build Coastguard Worker 
611*61046927SAndroid Build Coastguard Worker void *
vk_image_view_create(struct vk_device * device,bool driver_internal,const VkImageViewCreateInfo * pCreateInfo,const VkAllocationCallbacks * alloc,size_t size)612*61046927SAndroid Build Coastguard Worker vk_image_view_create(struct vk_device *device,
613*61046927SAndroid Build Coastguard Worker                      bool driver_internal,
614*61046927SAndroid Build Coastguard Worker                      const VkImageViewCreateInfo *pCreateInfo,
615*61046927SAndroid Build Coastguard Worker                      const VkAllocationCallbacks *alloc,
616*61046927SAndroid Build Coastguard Worker                      size_t size)
617*61046927SAndroid Build Coastguard Worker {
618*61046927SAndroid Build Coastguard Worker    struct vk_image_view *image_view =
619*61046927SAndroid Build Coastguard Worker       vk_zalloc2(&device->alloc, alloc, size, 8,
620*61046927SAndroid Build Coastguard Worker                  VK_SYSTEM_ALLOCATION_SCOPE_OBJECT);
621*61046927SAndroid Build Coastguard Worker    if (image_view == NULL)
622*61046927SAndroid Build Coastguard Worker       return NULL;
623*61046927SAndroid Build Coastguard Worker 
624*61046927SAndroid Build Coastguard Worker    vk_image_view_init(device, image_view, driver_internal, pCreateInfo);
625*61046927SAndroid Build Coastguard Worker 
626*61046927SAndroid Build Coastguard Worker    return image_view;
627*61046927SAndroid Build Coastguard Worker }
628*61046927SAndroid Build Coastguard Worker 
629*61046927SAndroid Build Coastguard Worker void
vk_image_view_destroy(struct vk_device * device,const VkAllocationCallbacks * alloc,struct vk_image_view * image_view)630*61046927SAndroid Build Coastguard Worker vk_image_view_destroy(struct vk_device *device,
631*61046927SAndroid Build Coastguard Worker                       const VkAllocationCallbacks *alloc,
632*61046927SAndroid Build Coastguard Worker                       struct vk_image_view *image_view)
633*61046927SAndroid Build Coastguard Worker {
634*61046927SAndroid Build Coastguard Worker    vk_object_free(device, alloc, image_view);
635*61046927SAndroid Build Coastguard Worker }
636*61046927SAndroid Build Coastguard Worker 
637*61046927SAndroid Build Coastguard Worker bool
vk_image_layout_is_read_only(VkImageLayout layout,VkImageAspectFlagBits aspect)638*61046927SAndroid Build Coastguard Worker vk_image_layout_is_read_only(VkImageLayout layout,
639*61046927SAndroid Build Coastguard Worker                              VkImageAspectFlagBits aspect)
640*61046927SAndroid Build Coastguard Worker {
641*61046927SAndroid Build Coastguard Worker    assert(util_bitcount(aspect) == 1);
642*61046927SAndroid Build Coastguard Worker 
643*61046927SAndroid Build Coastguard Worker    switch (layout) {
644*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_UNDEFINED:
645*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_PREINITIALIZED:
646*61046927SAndroid Build Coastguard Worker       return true; /* These are only used for layout transitions */
647*61046927SAndroid Build Coastguard Worker 
648*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_GENERAL:
649*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL:
650*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL:
651*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL:
652*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR:
653*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_OPTIMAL:
654*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_STENCIL_ATTACHMENT_OPTIMAL:
655*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_ATTACHMENT_OPTIMAL:
656*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_ATTACHMENT_FEEDBACK_LOOP_OPTIMAL_EXT:
657*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_RENDERING_LOCAL_READ_KHR:
658*61046927SAndroid Build Coastguard Worker       return false;
659*61046927SAndroid Build Coastguard Worker 
660*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL:
661*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL:
662*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL:
663*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_PRESENT_SRC_KHR:
664*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_FRAGMENT_SHADING_RATE_ATTACHMENT_OPTIMAL_KHR:
665*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_FRAGMENT_DENSITY_MAP_OPTIMAL_EXT:
666*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_OPTIMAL:
667*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_STENCIL_READ_ONLY_OPTIMAL:
668*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_READ_ONLY_OPTIMAL:
669*61046927SAndroid Build Coastguard Worker       return true;
670*61046927SAndroid Build Coastguard Worker 
671*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL:
672*61046927SAndroid Build Coastguard Worker       return aspect == VK_IMAGE_ASPECT_DEPTH_BIT;
673*61046927SAndroid Build Coastguard Worker 
674*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL:
675*61046927SAndroid Build Coastguard Worker       return aspect == VK_IMAGE_ASPECT_STENCIL_BIT;
676*61046927SAndroid Build Coastguard Worker 
677*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_MAX_ENUM:
678*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_VIDEO_DECODE_DST_KHR:
679*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_VIDEO_DECODE_SRC_KHR:
680*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_VIDEO_DECODE_DPB_KHR:
681*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_VIDEO_ENCODE_DST_KHR:
682*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_VIDEO_ENCODE_SRC_KHR:
683*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_VIDEO_ENCODE_DPB_KHR:
684*61046927SAndroid Build Coastguard Worker       unreachable("Invalid image layout.");
685*61046927SAndroid Build Coastguard Worker    }
686*61046927SAndroid Build Coastguard Worker 
687*61046927SAndroid Build Coastguard Worker    unreachable("Invalid image layout.");
688*61046927SAndroid Build Coastguard Worker }
689*61046927SAndroid Build Coastguard Worker 
690*61046927SAndroid Build Coastguard Worker bool
vk_image_layout_is_depth_only(VkImageLayout layout)691*61046927SAndroid Build Coastguard Worker vk_image_layout_is_depth_only(VkImageLayout layout)
692*61046927SAndroid Build Coastguard Worker {
693*61046927SAndroid Build Coastguard Worker    switch (layout) {
694*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_OPTIMAL:
695*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_OPTIMAL:
696*61046927SAndroid Build Coastguard Worker       return true;
697*61046927SAndroid Build Coastguard Worker 
698*61046927SAndroid Build Coastguard Worker    default:
699*61046927SAndroid Build Coastguard Worker       return false;
700*61046927SAndroid Build Coastguard Worker    }
701*61046927SAndroid Build Coastguard Worker }
702*61046927SAndroid Build Coastguard Worker 
703*61046927SAndroid Build Coastguard Worker static VkResult
vk_image_create_get_format_list_uncompressed(struct vk_device * device,const VkImageCreateInfo * pCreateInfo,const VkAllocationCallbacks * pAllocator,VkFormat ** formats,uint32_t * format_count)704*61046927SAndroid Build Coastguard Worker vk_image_create_get_format_list_uncompressed(struct vk_device *device,
705*61046927SAndroid Build Coastguard Worker                                              const VkImageCreateInfo *pCreateInfo,
706*61046927SAndroid Build Coastguard Worker                                              const VkAllocationCallbacks *pAllocator,
707*61046927SAndroid Build Coastguard Worker                                              VkFormat **formats,
708*61046927SAndroid Build Coastguard Worker                                              uint32_t *format_count)
709*61046927SAndroid Build Coastguard Worker {
710*61046927SAndroid Build Coastguard Worker    const struct vk_format_class_info *class =
711*61046927SAndroid Build Coastguard Worker       vk_format_get_class_info(pCreateInfo->format);
712*61046927SAndroid Build Coastguard Worker 
713*61046927SAndroid Build Coastguard Worker    *formats = NULL;
714*61046927SAndroid Build Coastguard Worker    *format_count = 0;
715*61046927SAndroid Build Coastguard Worker 
716*61046927SAndroid Build Coastguard Worker    if (class->format_count < 2)
717*61046927SAndroid Build Coastguard Worker       return VK_SUCCESS;
718*61046927SAndroid Build Coastguard Worker 
719*61046927SAndroid Build Coastguard Worker    *formats = vk_alloc2(&device->alloc, pAllocator,
720*61046927SAndroid Build Coastguard Worker                         sizeof(VkFormat) * class->format_count,
721*61046927SAndroid Build Coastguard Worker                         alignof(VkFormat), VK_SYSTEM_ALLOCATION_SCOPE_COMMAND);
722*61046927SAndroid Build Coastguard Worker    if (*formats == NULL)
723*61046927SAndroid Build Coastguard Worker       return vk_error(device, VK_ERROR_OUT_OF_HOST_MEMORY);
724*61046927SAndroid Build Coastguard Worker 
725*61046927SAndroid Build Coastguard Worker    memcpy(*formats, class->formats, sizeof(VkFormat) * class->format_count);
726*61046927SAndroid Build Coastguard Worker    *format_count = class->format_count;
727*61046927SAndroid Build Coastguard Worker 
728*61046927SAndroid Build Coastguard Worker    return VK_SUCCESS;
729*61046927SAndroid Build Coastguard Worker }
730*61046927SAndroid Build Coastguard Worker 
731*61046927SAndroid Build Coastguard Worker static VkResult
vk_image_create_get_format_list_compressed(struct vk_device * device,const VkImageCreateInfo * pCreateInfo,const VkAllocationCallbacks * pAllocator,VkFormat ** formats,uint32_t * format_count)732*61046927SAndroid Build Coastguard Worker vk_image_create_get_format_list_compressed(struct vk_device *device,
733*61046927SAndroid Build Coastguard Worker                                            const VkImageCreateInfo *pCreateInfo,
734*61046927SAndroid Build Coastguard Worker                                            const VkAllocationCallbacks *pAllocator,
735*61046927SAndroid Build Coastguard Worker                                            VkFormat **formats,
736*61046927SAndroid Build Coastguard Worker                                            uint32_t *format_count)
737*61046927SAndroid Build Coastguard Worker {
738*61046927SAndroid Build Coastguard Worker    if ((pCreateInfo->flags & VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT) == 0) {
739*61046927SAndroid Build Coastguard Worker       return vk_image_create_get_format_list_uncompressed(device,
740*61046927SAndroid Build Coastguard Worker                                                           pCreateInfo,
741*61046927SAndroid Build Coastguard Worker                                                           pAllocator,
742*61046927SAndroid Build Coastguard Worker                                                           formats,
743*61046927SAndroid Build Coastguard Worker                                                           format_count);
744*61046927SAndroid Build Coastguard Worker    }
745*61046927SAndroid Build Coastguard Worker 
746*61046927SAndroid Build Coastguard Worker    const struct vk_format_class_info *class =
747*61046927SAndroid Build Coastguard Worker       vk_format_get_class_info(pCreateInfo->format);
748*61046927SAndroid Build Coastguard Worker    const struct vk_format_class_info *uncompr_class = NULL;
749*61046927SAndroid Build Coastguard Worker 
750*61046927SAndroid Build Coastguard Worker    switch (vk_format_get_blocksizebits(pCreateInfo->format)) {
751*61046927SAndroid Build Coastguard Worker    case 64:
752*61046927SAndroid Build Coastguard Worker       uncompr_class = vk_format_class_get_info(MESA_VK_FORMAT_CLASS_64_BIT);
753*61046927SAndroid Build Coastguard Worker       break;
754*61046927SAndroid Build Coastguard Worker    case 128:
755*61046927SAndroid Build Coastguard Worker       uncompr_class = vk_format_class_get_info(MESA_VK_FORMAT_CLASS_128_BIT);
756*61046927SAndroid Build Coastguard Worker       break;
757*61046927SAndroid Build Coastguard Worker    }
758*61046927SAndroid Build Coastguard Worker 
759*61046927SAndroid Build Coastguard Worker    if (!uncompr_class)
760*61046927SAndroid Build Coastguard Worker       return vk_error(device, VK_ERROR_FORMAT_NOT_SUPPORTED);
761*61046927SAndroid Build Coastguard Worker 
762*61046927SAndroid Build Coastguard Worker    uint32_t fmt_count = class->format_count + uncompr_class->format_count;
763*61046927SAndroid Build Coastguard Worker 
764*61046927SAndroid Build Coastguard Worker    *formats = vk_alloc2(&device->alloc, pAllocator,
765*61046927SAndroid Build Coastguard Worker                         sizeof(VkFormat) * fmt_count,
766*61046927SAndroid Build Coastguard Worker                         alignof(VkFormat), VK_SYSTEM_ALLOCATION_SCOPE_COMMAND);
767*61046927SAndroid Build Coastguard Worker    if (*formats == NULL)
768*61046927SAndroid Build Coastguard Worker       return vk_error(device, VK_ERROR_OUT_OF_HOST_MEMORY);
769*61046927SAndroid Build Coastguard Worker 
770*61046927SAndroid Build Coastguard Worker    memcpy(*formats, class->formats, sizeof(VkFormat) * class->format_count);
771*61046927SAndroid Build Coastguard Worker    memcpy(*formats + class->format_count, uncompr_class->formats,
772*61046927SAndroid Build Coastguard Worker           sizeof(VkFormat) * uncompr_class->format_count);
773*61046927SAndroid Build Coastguard Worker    *format_count = class->format_count + uncompr_class->format_count;
774*61046927SAndroid Build Coastguard Worker 
775*61046927SAndroid Build Coastguard Worker    return VK_SUCCESS;
776*61046927SAndroid Build Coastguard Worker }
777*61046927SAndroid Build Coastguard Worker 
778*61046927SAndroid Build Coastguard Worker /* Get a list of compatible formats when VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT
779*61046927SAndroid Build Coastguard Worker  * or VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT is set. This list is
780*61046927SAndroid Build Coastguard Worker  * either retrieved from a VkImageFormatListCreateInfo passed to the creation
781*61046927SAndroid Build Coastguard Worker  * chain, or forged from the default compatible list specified in the
782*61046927SAndroid Build Coastguard Worker  * "formats-compatibility-classes" section of the spec.
783*61046927SAndroid Build Coastguard Worker  *
784*61046927SAndroid Build Coastguard Worker  * The value returned in *formats must be freed with
785*61046927SAndroid Build Coastguard Worker  * vk_free2(&device->alloc, pAllocator), and should not live past the
786*61046927SAndroid Build Coastguard Worker  * vkCreateImage() call (allocated in the COMMAND scope).
787*61046927SAndroid Build Coastguard Worker  */
788*61046927SAndroid Build Coastguard Worker VkResult
vk_image_create_get_format_list(struct vk_device * device,const VkImageCreateInfo * pCreateInfo,const VkAllocationCallbacks * pAllocator,VkFormat ** formats,uint32_t * format_count)789*61046927SAndroid Build Coastguard Worker vk_image_create_get_format_list(struct vk_device *device,
790*61046927SAndroid Build Coastguard Worker                                 const VkImageCreateInfo *pCreateInfo,
791*61046927SAndroid Build Coastguard Worker                                 const VkAllocationCallbacks *pAllocator,
792*61046927SAndroid Build Coastguard Worker                                 VkFormat **formats,
793*61046927SAndroid Build Coastguard Worker                                 uint32_t *format_count)
794*61046927SAndroid Build Coastguard Worker {
795*61046927SAndroid Build Coastguard Worker    *formats = NULL;
796*61046927SAndroid Build Coastguard Worker    *format_count = 0;
797*61046927SAndroid Build Coastguard Worker 
798*61046927SAndroid Build Coastguard Worker    if (!(pCreateInfo->flags &
799*61046927SAndroid Build Coastguard Worker          (VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT |
800*61046927SAndroid Build Coastguard Worker           VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT))) {
801*61046927SAndroid Build Coastguard Worker       return VK_SUCCESS;
802*61046927SAndroid Build Coastguard Worker    }
803*61046927SAndroid Build Coastguard Worker 
804*61046927SAndroid Build Coastguard Worker    /* "Each depth/stencil format is only compatible with itself." */
805*61046927SAndroid Build Coastguard Worker    if (vk_format_is_depth_or_stencil(pCreateInfo->format))
806*61046927SAndroid Build Coastguard Worker       return VK_SUCCESS;
807*61046927SAndroid Build Coastguard Worker 
808*61046927SAndroid Build Coastguard Worker    const VkImageFormatListCreateInfo *format_list = (const VkImageFormatListCreateInfo *)
809*61046927SAndroid Build Coastguard Worker       vk_find_struct_const(pCreateInfo->pNext, IMAGE_FORMAT_LIST_CREATE_INFO);
810*61046927SAndroid Build Coastguard Worker 
811*61046927SAndroid Build Coastguard Worker    if (format_list) {
812*61046927SAndroid Build Coastguard Worker       if (!format_list->viewFormatCount)
813*61046927SAndroid Build Coastguard Worker          return VK_SUCCESS;
814*61046927SAndroid Build Coastguard Worker 
815*61046927SAndroid Build Coastguard Worker       *formats = vk_alloc2(&device->alloc, pAllocator,
816*61046927SAndroid Build Coastguard Worker                            sizeof(VkFormat) * format_list->viewFormatCount,
817*61046927SAndroid Build Coastguard Worker                            alignof(VkFormat), VK_SYSTEM_ALLOCATION_SCOPE_COMMAND);
818*61046927SAndroid Build Coastguard Worker       if (*formats == NULL)
819*61046927SAndroid Build Coastguard Worker          return vk_error(device, VK_ERROR_OUT_OF_HOST_MEMORY);
820*61046927SAndroid Build Coastguard Worker 
821*61046927SAndroid Build Coastguard Worker       memcpy(*formats, format_list->pViewFormats, sizeof(VkFormat) * format_list->viewFormatCount);
822*61046927SAndroid Build Coastguard Worker       *format_count = format_list->viewFormatCount;
823*61046927SAndroid Build Coastguard Worker       return VK_SUCCESS;
824*61046927SAndroid Build Coastguard Worker    }
825*61046927SAndroid Build Coastguard Worker 
826*61046927SAndroid Build Coastguard Worker    if (vk_format_is_compressed(pCreateInfo->format))
827*61046927SAndroid Build Coastguard Worker       return vk_image_create_get_format_list_compressed(device,
828*61046927SAndroid Build Coastguard Worker                                                         pCreateInfo,
829*61046927SAndroid Build Coastguard Worker                                                         pAllocator,
830*61046927SAndroid Build Coastguard Worker                                                         formats,
831*61046927SAndroid Build Coastguard Worker                                                         format_count);
832*61046927SAndroid Build Coastguard Worker 
833*61046927SAndroid Build Coastguard Worker    return vk_image_create_get_format_list_uncompressed(device,
834*61046927SAndroid Build Coastguard Worker                                                        pCreateInfo,
835*61046927SAndroid Build Coastguard Worker                                                        pAllocator,
836*61046927SAndroid Build Coastguard Worker                                                        formats,
837*61046927SAndroid Build Coastguard Worker                                                        format_count);
838*61046927SAndroid Build Coastguard Worker }
839*61046927SAndroid Build Coastguard Worker 
840*61046927SAndroid Build Coastguard Worker /* From the Vulkan Specification 1.2.166 - VkAttachmentReference2:
841*61046927SAndroid Build Coastguard Worker  *
842*61046927SAndroid Build Coastguard Worker  *   "If layout only specifies the layout of the depth aspect of the
843*61046927SAndroid Build Coastguard Worker  *    attachment, the layout of the stencil aspect is specified by the
844*61046927SAndroid Build Coastguard Worker  *    stencilLayout member of a VkAttachmentReferenceStencilLayout structure
845*61046927SAndroid Build Coastguard Worker  *    included in the pNext chain. Otherwise, layout describes the layout for
846*61046927SAndroid Build Coastguard Worker  *    all relevant image aspects."
847*61046927SAndroid Build Coastguard Worker  */
848*61046927SAndroid Build Coastguard Worker VkImageLayout
vk_att_ref_stencil_layout(const VkAttachmentReference2 * att_ref,const VkAttachmentDescription2 * attachments)849*61046927SAndroid Build Coastguard Worker vk_att_ref_stencil_layout(const VkAttachmentReference2 *att_ref,
850*61046927SAndroid Build Coastguard Worker                           const VkAttachmentDescription2 *attachments)
851*61046927SAndroid Build Coastguard Worker {
852*61046927SAndroid Build Coastguard Worker    /* From VUID-VkAttachmentReference2-attachment-04755:
853*61046927SAndroid Build Coastguard Worker     *  "If attachment is not VK_ATTACHMENT_UNUSED, and the format of the
854*61046927SAndroid Build Coastguard Worker     *   referenced attachment is a depth/stencil format which includes both
855*61046927SAndroid Build Coastguard Worker     *   depth and stencil aspects [...]
856*61046927SAndroid Build Coastguard Worker     */
857*61046927SAndroid Build Coastguard Worker    if (att_ref->attachment == VK_ATTACHMENT_UNUSED ||
858*61046927SAndroid Build Coastguard Worker        !vk_format_has_stencil(attachments[att_ref->attachment].format))
859*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_LAYOUT_UNDEFINED;
860*61046927SAndroid Build Coastguard Worker 
861*61046927SAndroid Build Coastguard Worker    const VkAttachmentReferenceStencilLayout *stencil_ref =
862*61046927SAndroid Build Coastguard Worker       vk_find_struct_const(att_ref->pNext, ATTACHMENT_REFERENCE_STENCIL_LAYOUT);
863*61046927SAndroid Build Coastguard Worker 
864*61046927SAndroid Build Coastguard Worker    if (stencil_ref)
865*61046927SAndroid Build Coastguard Worker       return stencil_ref->stencilLayout;
866*61046927SAndroid Build Coastguard Worker 
867*61046927SAndroid Build Coastguard Worker    /* From VUID-VkAttachmentReference2-attachment-04755:
868*61046927SAndroid Build Coastguard Worker     *  "If attachment is not VK_ATTACHMENT_UNUSED, and the format of the
869*61046927SAndroid Build Coastguard Worker     *   referenced attachment is a depth/stencil format which includes both
870*61046927SAndroid Build Coastguard Worker     *   depth and stencil aspects, and layout is
871*61046927SAndroid Build Coastguard Worker     *   VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_OPTIMAL or
872*61046927SAndroid Build Coastguard Worker     *   VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_OPTIMAL, the pNext chain must include
873*61046927SAndroid Build Coastguard Worker     *   a VkAttachmentReferenceStencilLayout structure."
874*61046927SAndroid Build Coastguard Worker     */
875*61046927SAndroid Build Coastguard Worker    assert(!vk_image_layout_is_depth_only(att_ref->layout));
876*61046927SAndroid Build Coastguard Worker 
877*61046927SAndroid Build Coastguard Worker    return att_ref->layout;
878*61046927SAndroid Build Coastguard Worker }
879*61046927SAndroid Build Coastguard Worker 
880*61046927SAndroid Build Coastguard Worker /* From the Vulkan Specification 1.2.184:
881*61046927SAndroid Build Coastguard Worker  *
882*61046927SAndroid Build Coastguard Worker  *   "If the pNext chain includes a VkAttachmentDescriptionStencilLayout
883*61046927SAndroid Build Coastguard Worker  *    structure, then the stencilInitialLayout and stencilFinalLayout members
884*61046927SAndroid Build Coastguard Worker  *    specify the initial and final layouts of the stencil aspect of a
885*61046927SAndroid Build Coastguard Worker  *    depth/stencil format, and initialLayout and finalLayout only apply to the
886*61046927SAndroid Build Coastguard Worker  *    depth aspect. For depth-only formats, the
887*61046927SAndroid Build Coastguard Worker  *    VkAttachmentDescriptionStencilLayout structure is ignored. For
888*61046927SAndroid Build Coastguard Worker  *    stencil-only formats, the initial and final layouts of the stencil aspect
889*61046927SAndroid Build Coastguard Worker  *    are taken from the VkAttachmentDescriptionStencilLayout structure if
890*61046927SAndroid Build Coastguard Worker  *    present, or initialLayout and finalLayout if not present."
891*61046927SAndroid Build Coastguard Worker  *
892*61046927SAndroid Build Coastguard Worker  *   "If format is a depth/stencil format, and either initialLayout or
893*61046927SAndroid Build Coastguard Worker  *    finalLayout does not specify a layout for the stencil aspect, then the
894*61046927SAndroid Build Coastguard Worker  *    application must specify the initial and final layouts of the stencil
895*61046927SAndroid Build Coastguard Worker  *    aspect by including a VkAttachmentDescriptionStencilLayout structure in
896*61046927SAndroid Build Coastguard Worker  *    the pNext chain."
897*61046927SAndroid Build Coastguard Worker  */
898*61046927SAndroid Build Coastguard Worker VkImageLayout
vk_att_desc_stencil_layout(const VkAttachmentDescription2 * att_desc,bool final)899*61046927SAndroid Build Coastguard Worker vk_att_desc_stencil_layout(const VkAttachmentDescription2 *att_desc, bool final)
900*61046927SAndroid Build Coastguard Worker {
901*61046927SAndroid Build Coastguard Worker    if (!vk_format_has_stencil(att_desc->format))
902*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_LAYOUT_UNDEFINED;
903*61046927SAndroid Build Coastguard Worker 
904*61046927SAndroid Build Coastguard Worker    const VkAttachmentDescriptionStencilLayout *stencil_desc =
905*61046927SAndroid Build Coastguard Worker       vk_find_struct_const(att_desc->pNext, ATTACHMENT_DESCRIPTION_STENCIL_LAYOUT);
906*61046927SAndroid Build Coastguard Worker 
907*61046927SAndroid Build Coastguard Worker    if (stencil_desc) {
908*61046927SAndroid Build Coastguard Worker       return final ?
909*61046927SAndroid Build Coastguard Worker          stencil_desc->stencilFinalLayout :
910*61046927SAndroid Build Coastguard Worker          stencil_desc->stencilInitialLayout;
911*61046927SAndroid Build Coastguard Worker    }
912*61046927SAndroid Build Coastguard Worker 
913*61046927SAndroid Build Coastguard Worker    const VkImageLayout main_layout =
914*61046927SAndroid Build Coastguard Worker       final ? att_desc->finalLayout : att_desc->initialLayout;
915*61046927SAndroid Build Coastguard Worker 
916*61046927SAndroid Build Coastguard Worker    /* From VUID-VkAttachmentDescription2-format-03302/03303:
917*61046927SAndroid Build Coastguard Worker     *  "If format is a depth/stencil format which includes both depth and
918*61046927SAndroid Build Coastguard Worker     *   stencil aspects, and initial/finalLayout is
919*61046927SAndroid Build Coastguard Worker     *   VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_OPTIMAL or
920*61046927SAndroid Build Coastguard Worker     *   VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_OPTIMAL, the pNext chain must include
921*61046927SAndroid Build Coastguard Worker     *   a VkAttachmentDescriptionStencilLayout structure."
922*61046927SAndroid Build Coastguard Worker     */
923*61046927SAndroid Build Coastguard Worker    assert(!vk_image_layout_is_depth_only(main_layout));
924*61046927SAndroid Build Coastguard Worker 
925*61046927SAndroid Build Coastguard Worker    return main_layout;
926*61046927SAndroid Build Coastguard Worker }
927*61046927SAndroid Build Coastguard Worker 
928*61046927SAndroid Build Coastguard Worker VkImageUsageFlags
vk_image_layout_to_usage_flags(VkImageLayout layout,VkImageAspectFlagBits aspect)929*61046927SAndroid Build Coastguard Worker vk_image_layout_to_usage_flags(VkImageLayout layout,
930*61046927SAndroid Build Coastguard Worker                                VkImageAspectFlagBits aspect)
931*61046927SAndroid Build Coastguard Worker {
932*61046927SAndroid Build Coastguard Worker    assert(util_bitcount(aspect) == 1);
933*61046927SAndroid Build Coastguard Worker 
934*61046927SAndroid Build Coastguard Worker    switch (layout) {
935*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_UNDEFINED:
936*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_PREINITIALIZED:
937*61046927SAndroid Build Coastguard Worker       return 0u;
938*61046927SAndroid Build Coastguard Worker 
939*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_GENERAL:
940*61046927SAndroid Build Coastguard Worker       return ~0u;
941*61046927SAndroid Build Coastguard Worker 
942*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL:
943*61046927SAndroid Build Coastguard Worker       assert(aspect & VK_IMAGE_ASPECT_ANY_COLOR_MASK_MESA);
944*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT;
945*61046927SAndroid Build Coastguard Worker 
946*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL:
947*61046927SAndroid Build Coastguard Worker       assert(aspect & (VK_IMAGE_ASPECT_DEPTH_BIT |
948*61046927SAndroid Build Coastguard Worker                        VK_IMAGE_ASPECT_STENCIL_BIT));
949*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT;
950*61046927SAndroid Build Coastguard Worker 
951*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_OPTIMAL:
952*61046927SAndroid Build Coastguard Worker       assert(aspect & VK_IMAGE_ASPECT_DEPTH_BIT);
953*61046927SAndroid Build Coastguard Worker       return vk_image_layout_to_usage_flags(
954*61046927SAndroid Build Coastguard Worker          VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL, aspect);
955*61046927SAndroid Build Coastguard Worker 
956*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_STENCIL_ATTACHMENT_OPTIMAL:
957*61046927SAndroid Build Coastguard Worker       assert(aspect & VK_IMAGE_ASPECT_STENCIL_BIT);
958*61046927SAndroid Build Coastguard Worker       return vk_image_layout_to_usage_flags(
959*61046927SAndroid Build Coastguard Worker          VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL, aspect);
960*61046927SAndroid Build Coastguard Worker 
961*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL:
962*61046927SAndroid Build Coastguard Worker       assert(aspect & (VK_IMAGE_ASPECT_DEPTH_BIT |
963*61046927SAndroid Build Coastguard Worker                        VK_IMAGE_ASPECT_STENCIL_BIT));
964*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT |
965*61046927SAndroid Build Coastguard Worker              VK_IMAGE_USAGE_SAMPLED_BIT |
966*61046927SAndroid Build Coastguard Worker              VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT;
967*61046927SAndroid Build Coastguard Worker 
968*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_OPTIMAL:
969*61046927SAndroid Build Coastguard Worker       assert(aspect & VK_IMAGE_ASPECT_DEPTH_BIT);
970*61046927SAndroid Build Coastguard Worker       return vk_image_layout_to_usage_flags(
971*61046927SAndroid Build Coastguard Worker          VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL, aspect);
972*61046927SAndroid Build Coastguard Worker 
973*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_STENCIL_READ_ONLY_OPTIMAL:
974*61046927SAndroid Build Coastguard Worker       assert(aspect & VK_IMAGE_ASPECT_STENCIL_BIT);
975*61046927SAndroid Build Coastguard Worker       return vk_image_layout_to_usage_flags(
976*61046927SAndroid Build Coastguard Worker          VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL, aspect);
977*61046927SAndroid Build Coastguard Worker 
978*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL:
979*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_SAMPLED_BIT |
980*61046927SAndroid Build Coastguard Worker              VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT;
981*61046927SAndroid Build Coastguard Worker 
982*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL:
983*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_TRANSFER_SRC_BIT;
984*61046927SAndroid Build Coastguard Worker 
985*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL:
986*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_TRANSFER_DST_BIT;
987*61046927SAndroid Build Coastguard Worker 
988*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL:
989*61046927SAndroid Build Coastguard Worker       if (aspect == VK_IMAGE_ASPECT_DEPTH_BIT) {
990*61046927SAndroid Build Coastguard Worker          return vk_image_layout_to_usage_flags(
991*61046927SAndroid Build Coastguard Worker             VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL, aspect);
992*61046927SAndroid Build Coastguard Worker       } else if (aspect == VK_IMAGE_ASPECT_STENCIL_BIT) {
993*61046927SAndroid Build Coastguard Worker          return vk_image_layout_to_usage_flags(
994*61046927SAndroid Build Coastguard Worker             VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL, aspect);
995*61046927SAndroid Build Coastguard Worker       } else {
996*61046927SAndroid Build Coastguard Worker          assert(!"Must be a depth/stencil aspect");
997*61046927SAndroid Build Coastguard Worker          return 0;
998*61046927SAndroid Build Coastguard Worker       }
999*61046927SAndroid Build Coastguard Worker 
1000*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL:
1001*61046927SAndroid Build Coastguard Worker       if (aspect == VK_IMAGE_ASPECT_DEPTH_BIT) {
1002*61046927SAndroid Build Coastguard Worker          return vk_image_layout_to_usage_flags(
1003*61046927SAndroid Build Coastguard Worker             VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL, aspect);
1004*61046927SAndroid Build Coastguard Worker       } else if (aspect == VK_IMAGE_ASPECT_STENCIL_BIT) {
1005*61046927SAndroid Build Coastguard Worker          return vk_image_layout_to_usage_flags(
1006*61046927SAndroid Build Coastguard Worker             VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL, aspect);
1007*61046927SAndroid Build Coastguard Worker       } else {
1008*61046927SAndroid Build Coastguard Worker          assert(!"Must be a depth/stencil aspect");
1009*61046927SAndroid Build Coastguard Worker          return 0;
1010*61046927SAndroid Build Coastguard Worker       }
1011*61046927SAndroid Build Coastguard Worker 
1012*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_PRESENT_SRC_KHR:
1013*61046927SAndroid Build Coastguard Worker       assert(aspect == VK_IMAGE_ASPECT_COLOR_BIT);
1014*61046927SAndroid Build Coastguard Worker       /* This needs to be handled specially by the caller */
1015*61046927SAndroid Build Coastguard Worker       return 0;
1016*61046927SAndroid Build Coastguard Worker 
1017*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR:
1018*61046927SAndroid Build Coastguard Worker       assert(aspect == VK_IMAGE_ASPECT_COLOR_BIT);
1019*61046927SAndroid Build Coastguard Worker       return vk_image_layout_to_usage_flags(VK_IMAGE_LAYOUT_GENERAL, aspect);
1020*61046927SAndroid Build Coastguard Worker 
1021*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_FRAGMENT_SHADING_RATE_ATTACHMENT_OPTIMAL_KHR:
1022*61046927SAndroid Build Coastguard Worker       assert(aspect == VK_IMAGE_ASPECT_COLOR_BIT);
1023*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_FRAGMENT_SHADING_RATE_ATTACHMENT_BIT_KHR;
1024*61046927SAndroid Build Coastguard Worker 
1025*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_FRAGMENT_DENSITY_MAP_OPTIMAL_EXT:
1026*61046927SAndroid Build Coastguard Worker       assert(aspect == VK_IMAGE_ASPECT_COLOR_BIT);
1027*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_FRAGMENT_DENSITY_MAP_BIT_EXT;
1028*61046927SAndroid Build Coastguard Worker 
1029*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_ATTACHMENT_OPTIMAL:
1030*61046927SAndroid Build Coastguard Worker       if (aspect == VK_IMAGE_ASPECT_DEPTH_BIT ||
1031*61046927SAndroid Build Coastguard Worker           aspect == VK_IMAGE_ASPECT_STENCIL_BIT) {
1032*61046927SAndroid Build Coastguard Worker          return VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT;
1033*61046927SAndroid Build Coastguard Worker       } else {
1034*61046927SAndroid Build Coastguard Worker          assert(aspect == VK_IMAGE_ASPECT_COLOR_BIT);
1035*61046927SAndroid Build Coastguard Worker          return VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT;
1036*61046927SAndroid Build Coastguard Worker       }
1037*61046927SAndroid Build Coastguard Worker 
1038*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_READ_ONLY_OPTIMAL:
1039*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_SAMPLED_BIT |
1040*61046927SAndroid Build Coastguard Worker              VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT;
1041*61046927SAndroid Build Coastguard Worker 
1042*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_ATTACHMENT_FEEDBACK_LOOP_OPTIMAL_EXT:
1043*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_RENDERING_LOCAL_READ_KHR:
1044*61046927SAndroid Build Coastguard Worker       if (aspect == VK_IMAGE_ASPECT_DEPTH_BIT ||
1045*61046927SAndroid Build Coastguard Worker           aspect == VK_IMAGE_ASPECT_STENCIL_BIT) {
1046*61046927SAndroid Build Coastguard Worker          return VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT |
1047*61046927SAndroid Build Coastguard Worker                 VK_IMAGE_USAGE_SAMPLED_BIT |
1048*61046927SAndroid Build Coastguard Worker                 VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT |
1049*61046927SAndroid Build Coastguard Worker                 VK_IMAGE_USAGE_ATTACHMENT_FEEDBACK_LOOP_BIT_EXT;
1050*61046927SAndroid Build Coastguard Worker       } else {
1051*61046927SAndroid Build Coastguard Worker          assert(aspect == VK_IMAGE_ASPECT_COLOR_BIT);
1052*61046927SAndroid Build Coastguard Worker          return VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT |
1053*61046927SAndroid Build Coastguard Worker                 VK_IMAGE_USAGE_SAMPLED_BIT |
1054*61046927SAndroid Build Coastguard Worker                 VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT |
1055*61046927SAndroid Build Coastguard Worker                 VK_IMAGE_USAGE_ATTACHMENT_FEEDBACK_LOOP_BIT_EXT;
1056*61046927SAndroid Build Coastguard Worker       }
1057*61046927SAndroid Build Coastguard Worker 
1058*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_VIDEO_DECODE_DST_KHR:
1059*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_VIDEO_DECODE_DST_BIT_KHR;
1060*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_VIDEO_DECODE_SRC_KHR:
1061*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_VIDEO_DECODE_SRC_BIT_KHR;
1062*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_VIDEO_DECODE_DPB_KHR:
1063*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_VIDEO_DECODE_DPB_BIT_KHR;
1064*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_VIDEO_ENCODE_DST_KHR:
1065*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_VIDEO_ENCODE_DST_BIT_KHR;
1066*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_VIDEO_ENCODE_SRC_KHR:
1067*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_VIDEO_ENCODE_SRC_BIT_KHR;
1068*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_VIDEO_ENCODE_DPB_KHR:
1069*61046927SAndroid Build Coastguard Worker       return VK_IMAGE_USAGE_VIDEO_ENCODE_DPB_BIT_KHR;
1070*61046927SAndroid Build Coastguard Worker    case VK_IMAGE_LAYOUT_MAX_ENUM:
1071*61046927SAndroid Build Coastguard Worker       unreachable("Invalid image layout.");
1072*61046927SAndroid Build Coastguard Worker    }
1073*61046927SAndroid Build Coastguard Worker 
1074*61046927SAndroid Build Coastguard Worker    unreachable("Invalid image layout.");
1075*61046927SAndroid Build Coastguard Worker }
1076