Home | History | Annotate | Download | only in vulkan
      1 /*
      2  * Copyright  2015 Intel Corporation
      3  *
      4  * Permission is hereby granted, free of charge, to any person obtaining a
      5  * copy of this software and associated documentation files (the "Software"),
      6  * to deal in the Software without restriction, including without limitation
      7  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
      8  * and/or sell copies of the Software, and to permit persons to whom the
      9  * Software is furnished to do so, subject to the following conditions:
     10  *
     11  * The above copyright notice and this permission notice (including the next
     12  * paragraph) shall be included in all copies or substantial portions of the
     13  * Software.
     14  *
     15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
     16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
     17  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
     18  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
     19  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
     20  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
     21  * IN THE SOFTWARE.
     22  */
     23 
     24 #include "anv_private.h"
     25 #include "vk_enum_to_str.h"
     26 #include "vk_format_info.h"
     27 #include "vk_util.h"
     28 
     29 /*
     30  * gcc-4 and earlier don't allow compound literals where a constant
     31  * is required in -std=c99/gnu99 mode, so we can't use ISL_SWIZZLE()
     32  * here. -std=c89/gnu89 would allow it, but we depend on c99 features
     33  * so using -std=c89/gnu89 is not an option. Starting from gcc-5
     34  * compound literals can also be considered constant in -std=c99/gnu99
     35  * mode.
     36  */
     37 #define _ISL_SWIZZLE(r, g, b, a) { \
     38       ISL_CHANNEL_SELECT_##r, \
     39       ISL_CHANNEL_SELECT_##g, \
     40       ISL_CHANNEL_SELECT_##b, \
     41       ISL_CHANNEL_SELECT_##a, \
     42 }
     43 
     44 #define RGBA _ISL_SWIZZLE(RED, GREEN, BLUE, ALPHA)
     45 #define BGRA _ISL_SWIZZLE(BLUE, GREEN, RED, ALPHA)
     46 #define RGB1 _ISL_SWIZZLE(RED, GREEN, BLUE, ONE)
     47 
     48 #define swiz_fmt1(__vk_fmt, __hw_fmt, __swizzle) \
     49    [VK_ENUM_OFFSET(__vk_fmt)] = { \
     50       .planes = { \
     51          { .isl_format = __hw_fmt, .swizzle = __swizzle, \
     52            .denominator_scales = { 1, 1, }, \
     53          }, \
     54       }, \
     55       .n_planes = 1, \
     56    }
     57 
     58 #define fmt1(__vk_fmt, __hw_fmt) \
     59    swiz_fmt1(__vk_fmt, __hw_fmt, RGBA)
     60 
     61 #define fmt2(__vk_fmt, __fmt1, __fmt2) \
     62    [VK_ENUM_OFFSET(__vk_fmt)] = { \
     63       .planes = { \
     64          { .isl_format = __fmt1, \
     65            .swizzle = RGBA,       \
     66            .denominator_scales = { 1, 1, }, \
     67          }, \
     68          { .isl_format = __fmt2, \
     69            .swizzle = RGBA,       \
     70            .denominator_scales = { 1, 1, }, \
     71          }, \
     72       }, \
     73       .n_planes = 2, \
     74    }
     75 
     76 #define fmt_unsupported(__vk_fmt) \
     77    [VK_ENUM_OFFSET(__vk_fmt)] = { \
     78       .planes = { \
     79          { .isl_format = ISL_FORMAT_UNSUPPORTED, }, \
     80       }, \
     81    }
     82 
     83 #define y_plane(__hw_fmt, __swizzle, __ycbcr_swizzle, dhs, dvs) \
     84    { .isl_format = __hw_fmt, \
     85      .swizzle = __swizzle, \
     86      .ycbcr_swizzle = __ycbcr_swizzle, \
     87      .denominator_scales = { dhs, dvs, }, \
     88      .has_chroma = false, \
     89    }
     90 
     91 #define chroma_plane(__hw_fmt, __swizzle, __ycbcr_swizzle, dhs, dvs) \
     92    { .isl_format = __hw_fmt, \
     93      .swizzle = __swizzle, \
     94      .ycbcr_swizzle = __ycbcr_swizzle, \
     95      .denominator_scales = { dhs, dvs, }, \
     96      .has_chroma = true, \
     97    }
     98 
     99 #define ycbcr_fmt(__vk_fmt, __n_planes, ...) \
    100    [VK_ENUM_OFFSET(__vk_fmt)] = { \
    101       .planes = { \
    102          __VA_ARGS__, \
    103       }, \
    104       .n_planes = __n_planes, \
    105       .can_ycbcr = true, \
    106    }
    107 
    108 /* HINT: For array formats, the ISL name should match the VK name.  For
    109  * packed formats, they should have the channels in reverse order from each
    110  * other.  The reason for this is that, for packed formats, the ISL (and
    111  * bspec) names are in LSB -> MSB order while VK formats are MSB -> LSB.
    112  */
    113 static const struct anv_format main_formats[] = {
    114    fmt_unsupported(VK_FORMAT_UNDEFINED),
    115    fmt_unsupported(VK_FORMAT_R4G4_UNORM_PACK8),
    116    fmt1(VK_FORMAT_R4G4B4A4_UNORM_PACK16,             ISL_FORMAT_A4B4G4R4_UNORM),
    117    swiz_fmt1(VK_FORMAT_B4G4R4A4_UNORM_PACK16,        ISL_FORMAT_A4B4G4R4_UNORM,  BGRA),
    118    fmt1(VK_FORMAT_R5G6B5_UNORM_PACK16,               ISL_FORMAT_B5G6R5_UNORM),
    119    swiz_fmt1(VK_FORMAT_B5G6R5_UNORM_PACK16,          ISL_FORMAT_B5G6R5_UNORM, BGRA),
    120    fmt1(VK_FORMAT_R5G5B5A1_UNORM_PACK16,             ISL_FORMAT_A1B5G5R5_UNORM),
    121    fmt_unsupported(VK_FORMAT_B5G5R5A1_UNORM_PACK16),
    122    fmt1(VK_FORMAT_A1R5G5B5_UNORM_PACK16,             ISL_FORMAT_B5G5R5A1_UNORM),
    123    fmt1(VK_FORMAT_R8_UNORM,                          ISL_FORMAT_R8_UNORM),
    124    fmt1(VK_FORMAT_R8_SNORM,                          ISL_FORMAT_R8_SNORM),
    125    fmt1(VK_FORMAT_R8_USCALED,                        ISL_FORMAT_R8_USCALED),
    126    fmt1(VK_FORMAT_R8_SSCALED,                        ISL_FORMAT_R8_SSCALED),
    127    fmt1(VK_FORMAT_R8_UINT,                           ISL_FORMAT_R8_UINT),
    128    fmt1(VK_FORMAT_R8_SINT,                           ISL_FORMAT_R8_SINT),
    129    swiz_fmt1(VK_FORMAT_R8_SRGB,                      ISL_FORMAT_L8_UNORM_SRGB,
    130                                                      _ISL_SWIZZLE(RED, ZERO, ZERO, ONE)),
    131    fmt1(VK_FORMAT_R8G8_UNORM,                        ISL_FORMAT_R8G8_UNORM),
    132    fmt1(VK_FORMAT_R8G8_SNORM,                        ISL_FORMAT_R8G8_SNORM),
    133    fmt1(VK_FORMAT_R8G8_USCALED,                      ISL_FORMAT_R8G8_USCALED),
    134    fmt1(VK_FORMAT_R8G8_SSCALED,                      ISL_FORMAT_R8G8_SSCALED),
    135    fmt1(VK_FORMAT_R8G8_UINT,                         ISL_FORMAT_R8G8_UINT),
    136    fmt1(VK_FORMAT_R8G8_SINT,                         ISL_FORMAT_R8G8_SINT),
    137    fmt_unsupported(VK_FORMAT_R8G8_SRGB),             /* L8A8_UNORM_SRGB */
    138    fmt1(VK_FORMAT_R8G8B8_UNORM,                      ISL_FORMAT_R8G8B8_UNORM),
    139    fmt1(VK_FORMAT_R8G8B8_SNORM,                      ISL_FORMAT_R8G8B8_SNORM),
    140    fmt1(VK_FORMAT_R8G8B8_USCALED,                    ISL_FORMAT_R8G8B8_USCALED),
    141    fmt1(VK_FORMAT_R8G8B8_SSCALED,                    ISL_FORMAT_R8G8B8_SSCALED),
    142    fmt1(VK_FORMAT_R8G8B8_UINT,                       ISL_FORMAT_R8G8B8_UINT),
    143    fmt1(VK_FORMAT_R8G8B8_SINT,                       ISL_FORMAT_R8G8B8_SINT),
    144    fmt1(VK_FORMAT_R8G8B8_SRGB,                       ISL_FORMAT_R8G8B8_UNORM_SRGB),
    145    fmt1(VK_FORMAT_R8G8B8A8_UNORM,                    ISL_FORMAT_R8G8B8A8_UNORM),
    146    fmt1(VK_FORMAT_R8G8B8A8_SNORM,                    ISL_FORMAT_R8G8B8A8_SNORM),
    147    fmt1(VK_FORMAT_R8G8B8A8_USCALED,                  ISL_FORMAT_R8G8B8A8_USCALED),
    148    fmt1(VK_FORMAT_R8G8B8A8_SSCALED,                  ISL_FORMAT_R8G8B8A8_SSCALED),
    149    fmt1(VK_FORMAT_R8G8B8A8_UINT,                     ISL_FORMAT_R8G8B8A8_UINT),
    150    fmt1(VK_FORMAT_R8G8B8A8_SINT,                     ISL_FORMAT_R8G8B8A8_SINT),
    151    fmt1(VK_FORMAT_R8G8B8A8_SRGB,                     ISL_FORMAT_R8G8B8A8_UNORM_SRGB),
    152    fmt1(VK_FORMAT_A8B8G8R8_UNORM_PACK32,             ISL_FORMAT_R8G8B8A8_UNORM),
    153    fmt1(VK_FORMAT_A8B8G8R8_SNORM_PACK32,             ISL_FORMAT_R8G8B8A8_SNORM),
    154    fmt1(VK_FORMAT_A8B8G8R8_USCALED_PACK32,           ISL_FORMAT_R8G8B8A8_USCALED),
    155    fmt1(VK_FORMAT_A8B8G8R8_SSCALED_PACK32,           ISL_FORMAT_R8G8B8A8_SSCALED),
    156    fmt1(VK_FORMAT_A8B8G8R8_UINT_PACK32,              ISL_FORMAT_R8G8B8A8_UINT),
    157    fmt1(VK_FORMAT_A8B8G8R8_SINT_PACK32,              ISL_FORMAT_R8G8B8A8_SINT),
    158    fmt1(VK_FORMAT_A8B8G8R8_SRGB_PACK32,              ISL_FORMAT_R8G8B8A8_UNORM_SRGB),
    159    fmt1(VK_FORMAT_A2R10G10B10_UNORM_PACK32,          ISL_FORMAT_B10G10R10A2_UNORM),
    160    fmt1(VK_FORMAT_A2R10G10B10_SNORM_PACK32,          ISL_FORMAT_B10G10R10A2_SNORM),
    161    fmt1(VK_FORMAT_A2R10G10B10_USCALED_PACK32,        ISL_FORMAT_B10G10R10A2_USCALED),
    162    fmt1(VK_FORMAT_A2R10G10B10_SSCALED_PACK32,        ISL_FORMAT_B10G10R10A2_SSCALED),
    163    fmt1(VK_FORMAT_A2R10G10B10_UINT_PACK32,           ISL_FORMAT_B10G10R10A2_UINT),
    164    fmt1(VK_FORMAT_A2R10G10B10_SINT_PACK32,           ISL_FORMAT_B10G10R10A2_SINT),
    165    fmt1(VK_FORMAT_A2B10G10R10_UNORM_PACK32,          ISL_FORMAT_R10G10B10A2_UNORM),
    166    fmt1(VK_FORMAT_A2B10G10R10_SNORM_PACK32,          ISL_FORMAT_R10G10B10A2_SNORM),
    167    fmt1(VK_FORMAT_A2B10G10R10_USCALED_PACK32,        ISL_FORMAT_R10G10B10A2_USCALED),
    168    fmt1(VK_FORMAT_A2B10G10R10_SSCALED_PACK32,        ISL_FORMAT_R10G10B10A2_SSCALED),
    169    fmt1(VK_FORMAT_A2B10G10R10_UINT_PACK32,           ISL_FORMAT_R10G10B10A2_UINT),
    170    fmt1(VK_FORMAT_A2B10G10R10_SINT_PACK32,           ISL_FORMAT_R10G10B10A2_SINT),
    171    fmt1(VK_FORMAT_R16_UNORM,                         ISL_FORMAT_R16_UNORM),
    172    fmt1(VK_FORMAT_R16_SNORM,                         ISL_FORMAT_R16_SNORM),
    173    fmt1(VK_FORMAT_R16_USCALED,                       ISL_FORMAT_R16_USCALED),
    174    fmt1(VK_FORMAT_R16_SSCALED,                       ISL_FORMAT_R16_SSCALED),
    175    fmt1(VK_FORMAT_R16_UINT,                          ISL_FORMAT_R16_UINT),
    176    fmt1(VK_FORMAT_R16_SINT,                          ISL_FORMAT_R16_SINT),
    177    fmt1(VK_FORMAT_R16_SFLOAT,                        ISL_FORMAT_R16_FLOAT),
    178    fmt1(VK_FORMAT_R16G16_UNORM,                      ISL_FORMAT_R16G16_UNORM),
    179    fmt1(VK_FORMAT_R16G16_SNORM,                      ISL_FORMAT_R16G16_SNORM),
    180    fmt1(VK_FORMAT_R16G16_USCALED,                    ISL_FORMAT_R16G16_USCALED),
    181    fmt1(VK_FORMAT_R16G16_SSCALED,                    ISL_FORMAT_R16G16_SSCALED),
    182    fmt1(VK_FORMAT_R16G16_UINT,                       ISL_FORMAT_R16G16_UINT),
    183    fmt1(VK_FORMAT_R16G16_SINT,                       ISL_FORMAT_R16G16_SINT),
    184    fmt1(VK_FORMAT_R16G16_SFLOAT,                     ISL_FORMAT_R16G16_FLOAT),
    185    fmt1(VK_FORMAT_R16G16B16_UNORM,                   ISL_FORMAT_R16G16B16_UNORM),
    186    fmt1(VK_FORMAT_R16G16B16_SNORM,                   ISL_FORMAT_R16G16B16_SNORM),
    187    fmt1(VK_FORMAT_R16G16B16_USCALED,                 ISL_FORMAT_R16G16B16_USCALED),
    188    fmt1(VK_FORMAT_R16G16B16_SSCALED,                 ISL_FORMAT_R16G16B16_SSCALED),
    189    fmt1(VK_FORMAT_R16G16B16_UINT,                    ISL_FORMAT_R16G16B16_UINT),
    190    fmt1(VK_FORMAT_R16G16B16_SINT,                    ISL_FORMAT_R16G16B16_SINT),
    191    fmt1(VK_FORMAT_R16G16B16_SFLOAT,                  ISL_FORMAT_R16G16B16_FLOAT),
    192    fmt1(VK_FORMAT_R16G16B16A16_UNORM,                ISL_FORMAT_R16G16B16A16_UNORM),
    193    fmt1(VK_FORMAT_R16G16B16A16_SNORM,                ISL_FORMAT_R16G16B16A16_SNORM),
    194    fmt1(VK_FORMAT_R16G16B16A16_USCALED,              ISL_FORMAT_R16G16B16A16_USCALED),
    195    fmt1(VK_FORMAT_R16G16B16A16_SSCALED,              ISL_FORMAT_R16G16B16A16_SSCALED),
    196    fmt1(VK_FORMAT_R16G16B16A16_UINT,                 ISL_FORMAT_R16G16B16A16_UINT),
    197    fmt1(VK_FORMAT_R16G16B16A16_SINT,                 ISL_FORMAT_R16G16B16A16_SINT),
    198    fmt1(VK_FORMAT_R16G16B16A16_SFLOAT,               ISL_FORMAT_R16G16B16A16_FLOAT),
    199    fmt1(VK_FORMAT_R32_UINT,                          ISL_FORMAT_R32_UINT),
    200    fmt1(VK_FORMAT_R32_SINT,                          ISL_FORMAT_R32_SINT),
    201    fmt1(VK_FORMAT_R32_SFLOAT,                        ISL_FORMAT_R32_FLOAT),
    202    fmt1(VK_FORMAT_R32G32_UINT,                       ISL_FORMAT_R32G32_UINT),
    203    fmt1(VK_FORMAT_R32G32_SINT,                       ISL_FORMAT_R32G32_SINT),
    204    fmt1(VK_FORMAT_R32G32_SFLOAT,                     ISL_FORMAT_R32G32_FLOAT),
    205    fmt1(VK_FORMAT_R32G32B32_UINT,                    ISL_FORMAT_R32G32B32_UINT),
    206    fmt1(VK_FORMAT_R32G32B32_SINT,                    ISL_FORMAT_R32G32B32_SINT),
    207    fmt1(VK_FORMAT_R32G32B32_SFLOAT,                  ISL_FORMAT_R32G32B32_FLOAT),
    208    fmt1(VK_FORMAT_R32G32B32A32_UINT,                 ISL_FORMAT_R32G32B32A32_UINT),
    209    fmt1(VK_FORMAT_R32G32B32A32_SINT,                 ISL_FORMAT_R32G32B32A32_SINT),
    210    fmt1(VK_FORMAT_R32G32B32A32_SFLOAT,               ISL_FORMAT_R32G32B32A32_FLOAT),
    211    fmt1(VK_FORMAT_R64_UINT,                          ISL_FORMAT_R64_PASSTHRU),
    212    fmt1(VK_FORMAT_R64_SINT,                          ISL_FORMAT_R64_PASSTHRU),
    213    fmt1(VK_FORMAT_R64_SFLOAT,                        ISL_FORMAT_R64_PASSTHRU),
    214    fmt1(VK_FORMAT_R64G64_UINT,                       ISL_FORMAT_R64G64_PASSTHRU),
    215    fmt1(VK_FORMAT_R64G64_SINT,                       ISL_FORMAT_R64G64_PASSTHRU),
    216    fmt1(VK_FORMAT_R64G64_SFLOAT,                     ISL_FORMAT_R64G64_PASSTHRU),
    217    fmt1(VK_FORMAT_R64G64B64_UINT,                    ISL_FORMAT_R64G64B64_PASSTHRU),
    218    fmt1(VK_FORMAT_R64G64B64_SINT,                    ISL_FORMAT_R64G64B64_PASSTHRU),
    219    fmt1(VK_FORMAT_R64G64B64_SFLOAT,                  ISL_FORMAT_R64G64B64_PASSTHRU),
    220    fmt1(VK_FORMAT_R64G64B64A64_UINT,                 ISL_FORMAT_R64G64B64A64_PASSTHRU),
    221    fmt1(VK_FORMAT_R64G64B64A64_SINT,                 ISL_FORMAT_R64G64B64A64_PASSTHRU),
    222    fmt1(VK_FORMAT_R64G64B64A64_SFLOAT,               ISL_FORMAT_R64G64B64A64_PASSTHRU),
    223    fmt1(VK_FORMAT_B10G11R11_UFLOAT_PACK32,           ISL_FORMAT_R11G11B10_FLOAT),
    224    fmt1(VK_FORMAT_E5B9G9R9_UFLOAT_PACK32,            ISL_FORMAT_R9G9B9E5_SHAREDEXP),
    225 
    226    fmt1(VK_FORMAT_D16_UNORM,                         ISL_FORMAT_R16_UNORM),
    227    fmt1(VK_FORMAT_X8_D24_UNORM_PACK32,               ISL_FORMAT_R24_UNORM_X8_TYPELESS),
    228    fmt1(VK_FORMAT_D32_SFLOAT,                        ISL_FORMAT_R32_FLOAT),
    229    fmt1(VK_FORMAT_S8_UINT,                           ISL_FORMAT_R8_UINT),
    230    fmt_unsupported(VK_FORMAT_D16_UNORM_S8_UINT),
    231    fmt2(VK_FORMAT_D24_UNORM_S8_UINT,                 ISL_FORMAT_R24_UNORM_X8_TYPELESS, ISL_FORMAT_R8_UINT),
    232    fmt2(VK_FORMAT_D32_SFLOAT_S8_UINT,                ISL_FORMAT_R32_FLOAT, ISL_FORMAT_R8_UINT),
    233 
    234    swiz_fmt1(VK_FORMAT_BC1_RGB_UNORM_BLOCK,          ISL_FORMAT_BC1_UNORM, RGB1),
    235    swiz_fmt1(VK_FORMAT_BC1_RGB_SRGB_BLOCK,           ISL_FORMAT_BC1_UNORM_SRGB, RGB1),
    236    fmt1(VK_FORMAT_BC1_RGBA_UNORM_BLOCK,              ISL_FORMAT_BC1_UNORM),
    237    fmt1(VK_FORMAT_BC1_RGBA_SRGB_BLOCK,               ISL_FORMAT_BC1_UNORM_SRGB),
    238    fmt1(VK_FORMAT_BC2_UNORM_BLOCK,                   ISL_FORMAT_BC2_UNORM),
    239    fmt1(VK_FORMAT_BC2_SRGB_BLOCK,                    ISL_FORMAT_BC2_UNORM_SRGB),
    240    fmt1(VK_FORMAT_BC3_UNORM_BLOCK,                   ISL_FORMAT_BC3_UNORM),
    241    fmt1(VK_FORMAT_BC3_SRGB_BLOCK,                    ISL_FORMAT_BC3_UNORM_SRGB),
    242    fmt1(VK_FORMAT_BC4_UNORM_BLOCK,                   ISL_FORMAT_BC4_UNORM),
    243    fmt1(VK_FORMAT_BC4_SNORM_BLOCK,                   ISL_FORMAT_BC4_SNORM),
    244    fmt1(VK_FORMAT_BC5_UNORM_BLOCK,                   ISL_FORMAT_BC5_UNORM),
    245    fmt1(VK_FORMAT_BC5_SNORM_BLOCK,                   ISL_FORMAT_BC5_SNORM),
    246    fmt1(VK_FORMAT_BC6H_UFLOAT_BLOCK,                 ISL_FORMAT_BC6H_UF16),
    247    fmt1(VK_FORMAT_BC6H_SFLOAT_BLOCK,                 ISL_FORMAT_BC6H_SF16),
    248    fmt1(VK_FORMAT_BC7_UNORM_BLOCK,                   ISL_FORMAT_BC7_UNORM),
    249    fmt1(VK_FORMAT_BC7_SRGB_BLOCK,                    ISL_FORMAT_BC7_UNORM_SRGB),
    250    fmt1(VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK,           ISL_FORMAT_ETC2_RGB8),
    251    fmt1(VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK,            ISL_FORMAT_ETC2_SRGB8),
    252    fmt1(VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK,         ISL_FORMAT_ETC2_RGB8_PTA),
    253    fmt1(VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK,          ISL_FORMAT_ETC2_SRGB8_PTA),
    254    fmt1(VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK,         ISL_FORMAT_ETC2_EAC_RGBA8),
    255    fmt1(VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK,          ISL_FORMAT_ETC2_EAC_SRGB8_A8),
    256    fmt1(VK_FORMAT_EAC_R11_UNORM_BLOCK,               ISL_FORMAT_EAC_R11),
    257    fmt1(VK_FORMAT_EAC_R11_SNORM_BLOCK,               ISL_FORMAT_EAC_SIGNED_R11),
    258    fmt1(VK_FORMAT_EAC_R11G11_UNORM_BLOCK,            ISL_FORMAT_EAC_RG11),
    259    fmt1(VK_FORMAT_EAC_R11G11_SNORM_BLOCK,            ISL_FORMAT_EAC_SIGNED_RG11),
    260    fmt1(VK_FORMAT_ASTC_4x4_SRGB_BLOCK,               ISL_FORMAT_ASTC_LDR_2D_4X4_U8SRGB),
    261    fmt1(VK_FORMAT_ASTC_5x4_SRGB_BLOCK,               ISL_FORMAT_ASTC_LDR_2D_5X4_U8SRGB),
    262    fmt1(VK_FORMAT_ASTC_5x5_SRGB_BLOCK,               ISL_FORMAT_ASTC_LDR_2D_5X5_U8SRGB),
    263    fmt1(VK_FORMAT_ASTC_6x5_SRGB_BLOCK,               ISL_FORMAT_ASTC_LDR_2D_6X5_U8SRGB),
    264    fmt1(VK_FORMAT_ASTC_6x6_SRGB_BLOCK,               ISL_FORMAT_ASTC_LDR_2D_6X6_U8SRGB),
    265    fmt1(VK_FORMAT_ASTC_8x5_SRGB_BLOCK,               ISL_FORMAT_ASTC_LDR_2D_8X5_U8SRGB),
    266    fmt1(VK_FORMAT_ASTC_8x6_SRGB_BLOCK,               ISL_FORMAT_ASTC_LDR_2D_8X6_U8SRGB),
    267    fmt1(VK_FORMAT_ASTC_8x8_SRGB_BLOCK,               ISL_FORMAT_ASTC_LDR_2D_8X8_U8SRGB),
    268    fmt1(VK_FORMAT_ASTC_10x5_SRGB_BLOCK,              ISL_FORMAT_ASTC_LDR_2D_10X5_U8SRGB),
    269    fmt1(VK_FORMAT_ASTC_10x6_SRGB_BLOCK,              ISL_FORMAT_ASTC_LDR_2D_10X6_U8SRGB),
    270    fmt1(VK_FORMAT_ASTC_10x8_SRGB_BLOCK,              ISL_FORMAT_ASTC_LDR_2D_10X8_U8SRGB),
    271    fmt1(VK_FORMAT_ASTC_10x10_SRGB_BLOCK,             ISL_FORMAT_ASTC_LDR_2D_10X10_U8SRGB),
    272    fmt1(VK_FORMAT_ASTC_12x10_SRGB_BLOCK,             ISL_FORMAT_ASTC_LDR_2D_12X10_U8SRGB),
    273    fmt1(VK_FORMAT_ASTC_12x12_SRGB_BLOCK,             ISL_FORMAT_ASTC_LDR_2D_12X12_U8SRGB),
    274    fmt1(VK_FORMAT_ASTC_4x4_UNORM_BLOCK,              ISL_FORMAT_ASTC_LDR_2D_4X4_FLT16),
    275    fmt1(VK_FORMAT_ASTC_5x4_UNORM_BLOCK,              ISL_FORMAT_ASTC_LDR_2D_5X4_FLT16),
    276    fmt1(VK_FORMAT_ASTC_5x5_UNORM_BLOCK,              ISL_FORMAT_ASTC_LDR_2D_5X5_FLT16),
    277    fmt1(VK_FORMAT_ASTC_6x5_UNORM_BLOCK,              ISL_FORMAT_ASTC_LDR_2D_6X5_FLT16),
    278    fmt1(VK_FORMAT_ASTC_6x6_UNORM_BLOCK,              ISL_FORMAT_ASTC_LDR_2D_6X6_FLT16),
    279    fmt1(VK_FORMAT_ASTC_8x5_UNORM_BLOCK,              ISL_FORMAT_ASTC_LDR_2D_8X5_FLT16),
    280    fmt1(VK_FORMAT_ASTC_8x6_UNORM_BLOCK,              ISL_FORMAT_ASTC_LDR_2D_8X6_FLT16),
    281    fmt1(VK_FORMAT_ASTC_8x8_UNORM_BLOCK,              ISL_FORMAT_ASTC_LDR_2D_8X8_FLT16),
    282    fmt1(VK_FORMAT_ASTC_10x5_UNORM_BLOCK,             ISL_FORMAT_ASTC_LDR_2D_10X5_FLT16),
    283    fmt1(VK_FORMAT_ASTC_10x6_UNORM_BLOCK,             ISL_FORMAT_ASTC_LDR_2D_10X6_FLT16),
    284    fmt1(VK_FORMAT_ASTC_10x8_UNORM_BLOCK,             ISL_FORMAT_ASTC_LDR_2D_10X8_FLT16),
    285    fmt1(VK_FORMAT_ASTC_10x10_UNORM_BLOCK,            ISL_FORMAT_ASTC_LDR_2D_10X10_FLT16),
    286    fmt1(VK_FORMAT_ASTC_12x10_UNORM_BLOCK,            ISL_FORMAT_ASTC_LDR_2D_12X10_FLT16),
    287    fmt1(VK_FORMAT_ASTC_12x12_UNORM_BLOCK,            ISL_FORMAT_ASTC_LDR_2D_12X12_FLT16),
    288    fmt_unsupported(VK_FORMAT_B8G8R8_UNORM),
    289    fmt_unsupported(VK_FORMAT_B8G8R8_SNORM),
    290    fmt_unsupported(VK_FORMAT_B8G8R8_USCALED),
    291    fmt_unsupported(VK_FORMAT_B8G8R8_SSCALED),
    292    fmt_unsupported(VK_FORMAT_B8G8R8_UINT),
    293    fmt_unsupported(VK_FORMAT_B8G8R8_SINT),
    294    fmt_unsupported(VK_FORMAT_B8G8R8_SRGB),
    295    fmt1(VK_FORMAT_B8G8R8A8_UNORM,                    ISL_FORMAT_B8G8R8A8_UNORM),
    296    fmt_unsupported(VK_FORMAT_B8G8R8A8_SNORM),
    297    fmt_unsupported(VK_FORMAT_B8G8R8A8_USCALED),
    298    fmt_unsupported(VK_FORMAT_B8G8R8A8_SSCALED),
    299    fmt_unsupported(VK_FORMAT_B8G8R8A8_UINT),
    300    fmt_unsupported(VK_FORMAT_B8G8R8A8_SINT),
    301    fmt1(VK_FORMAT_B8G8R8A8_SRGB,                     ISL_FORMAT_B8G8R8A8_UNORM_SRGB),
    302 };
    303 
    304 static const struct anv_format ycbcr_formats[] = {
    305    ycbcr_fmt(VK_FORMAT_G8B8G8R8_422_UNORM_KHR, 1,
    306              y_plane(ISL_FORMAT_YCRCB_SWAPUV, RGBA, _ISL_SWIZZLE(BLUE, GREEN, RED, ZERO), 1, 1)),
    307    ycbcr_fmt(VK_FORMAT_B8G8R8G8_422_UNORM_KHR, 1,
    308              y_plane(ISL_FORMAT_YCRCB_SWAPUVY, RGBA, _ISL_SWIZZLE(BLUE, GREEN, RED, ZERO), 1, 1)),
    309    ycbcr_fmt(VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM_KHR, 3,
    310              y_plane(ISL_FORMAT_R8_UNORM, RGBA, _ISL_SWIZZLE(GREEN, ZERO, ZERO, ZERO), 1, 1),
    311              chroma_plane(ISL_FORMAT_R8_UNORM, RGBA, _ISL_SWIZZLE(BLUE, ZERO, ZERO, ZERO), 2, 2),
    312              chroma_plane(ISL_FORMAT_R8_UNORM, RGBA, _ISL_SWIZZLE(RED, ZERO, ZERO, ZERO), 2, 2)),
    313    ycbcr_fmt(VK_FORMAT_G8_B8R8_2PLANE_420_UNORM_KHR, 2,
    314              y_plane(ISL_FORMAT_R8_UNORM, RGBA, _ISL_SWIZZLE(GREEN, ZERO, ZERO, ZERO), 1, 1),
    315              chroma_plane(ISL_FORMAT_R8G8_UNORM, RGBA, _ISL_SWIZZLE(BLUE, RED, ZERO, ZERO), 2, 2)),
    316    ycbcr_fmt(VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM_KHR, 3,
    317              y_plane(ISL_FORMAT_R8_UNORM, RGBA, _ISL_SWIZZLE(GREEN, ZERO, ZERO, ZERO), 1, 1),
    318              chroma_plane(ISL_FORMAT_R8_UNORM, RGBA, _ISL_SWIZZLE(BLUE, ZERO, ZERO, ZERO), 2, 1),
    319              chroma_plane(ISL_FORMAT_R8_UNORM, RGBA, _ISL_SWIZZLE(RED, ZERO, ZERO, ZERO), 2, 1)),
    320    ycbcr_fmt(VK_FORMAT_G8_B8R8_2PLANE_422_UNORM_KHR, 2,
    321              y_plane(ISL_FORMAT_R8_UNORM, RGBA, _ISL_SWIZZLE(GREEN, ZERO, ZERO, ZERO), 1, 1),
    322              chroma_plane(ISL_FORMAT_R8G8_UNORM, RGBA, _ISL_SWIZZLE(BLUE, RED, ZERO, ZERO), 2, 1)),
    323    ycbcr_fmt(VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM_KHR, 3,
    324              y_plane(ISL_FORMAT_R8_UNORM, RGBA, _ISL_SWIZZLE(GREEN, ZERO, ZERO, ZERO), 1, 1),
    325              chroma_plane(ISL_FORMAT_R8_UNORM, RGBA, _ISL_SWIZZLE(BLUE, ZERO, ZERO, ZERO), 1, 1),
    326              chroma_plane(ISL_FORMAT_R8_UNORM, RGBA, _ISL_SWIZZLE(RED, ZERO, ZERO, ZERO), 1, 1)),
    327 
    328    fmt_unsupported(VK_FORMAT_R10X6_UNORM_PACK16_KHR),
    329    fmt_unsupported(VK_FORMAT_R10X6G10X6_UNORM_2PACK16_KHR),
    330    fmt_unsupported(VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16_KHR),
    331    fmt_unsupported(VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16_KHR),
    332    fmt_unsupported(VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16_KHR),
    333    fmt_unsupported(VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16_KHR),
    334    fmt_unsupported(VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16_KHR),
    335    fmt_unsupported(VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16_KHR),
    336    fmt_unsupported(VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16_KHR),
    337    fmt_unsupported(VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16_KHR),
    338    fmt_unsupported(VK_FORMAT_R12X4_UNORM_PACK16_KHR),
    339    fmt_unsupported(VK_FORMAT_R12X4G12X4_UNORM_2PACK16_KHR),
    340    fmt_unsupported(VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16_KHR),
    341    fmt_unsupported(VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16_KHR),
    342    fmt_unsupported(VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16_KHR),
    343    fmt_unsupported(VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16_KHR),
    344    fmt_unsupported(VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16_KHR),
    345    fmt_unsupported(VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16_KHR),
    346    fmt_unsupported(VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16_KHR),
    347    fmt_unsupported(VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16_KHR),
    348    /* TODO: it is possible to enable the following 2 formats, but that
    349     * requires further refactoring of how we handle multiplanar formats.
    350     */
    351    fmt_unsupported(VK_FORMAT_G16B16G16R16_422_UNORM_KHR),
    352    fmt_unsupported(VK_FORMAT_B16G16R16G16_422_UNORM_KHR),
    353 
    354    ycbcr_fmt(VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM_KHR, 3,
    355              y_plane(ISL_FORMAT_R16_UNORM, RGBA, _ISL_SWIZZLE(GREEN, ZERO, ZERO, ZERO), 1, 1),
    356              chroma_plane(ISL_FORMAT_R16_UNORM, RGBA, _ISL_SWIZZLE(BLUE, ZERO, ZERO, ZERO), 2, 2),
    357              chroma_plane(ISL_FORMAT_R16_UNORM, RGBA, _ISL_SWIZZLE(RED, ZERO, ZERO, ZERO), 2, 2)),
    358    ycbcr_fmt(VK_FORMAT_G16_B16R16_2PLANE_420_UNORM_KHR, 2,
    359              y_plane(ISL_FORMAT_R16_UNORM, RGBA, _ISL_SWIZZLE(GREEN, ZERO, ZERO, ZERO), 1, 1),
    360              chroma_plane(ISL_FORMAT_R16G16_UNORM, RGBA, _ISL_SWIZZLE(BLUE, RED, ZERO, ZERO), 2, 2)),
    361    ycbcr_fmt(VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM_KHR, 3,
    362              y_plane(ISL_FORMAT_R16_UNORM, RGBA, _ISL_SWIZZLE(GREEN, ZERO, ZERO, ZERO), 1, 1),
    363              chroma_plane(ISL_FORMAT_R16_UNORM, RGBA, _ISL_SWIZZLE(BLUE, ZERO, ZERO, ZERO), 2, 1),
    364              chroma_plane(ISL_FORMAT_R16_UNORM, RGBA, _ISL_SWIZZLE(RED, ZERO, ZERO, ZERO), 2, 1)),
    365    ycbcr_fmt(VK_FORMAT_G16_B16R16_2PLANE_422_UNORM_KHR, 2,
    366              y_plane(ISL_FORMAT_R16_UNORM, RGBA, _ISL_SWIZZLE(GREEN, ZERO, ZERO, ZERO), 1, 1),
    367              chroma_plane(ISL_FORMAT_R16G16_UNORM, RGBA, _ISL_SWIZZLE(BLUE, RED, ZERO, ZERO), 2, 1)),
    368    ycbcr_fmt(VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM_KHR, 3,
    369              y_plane(ISL_FORMAT_R16_UNORM, RGBA, _ISL_SWIZZLE(GREEN, ZERO, ZERO, ZERO), 1, 1),
    370              chroma_plane(ISL_FORMAT_R16_UNORM, RGBA, _ISL_SWIZZLE(BLUE, ZERO, ZERO, ZERO), 1, 1),
    371              chroma_plane(ISL_FORMAT_R16_UNORM, RGBA, _ISL_SWIZZLE(RED, ZERO, ZERO, ZERO), 1, 1)),
    372 };
    373 
    374 #undef _fmt
    375 #undef swiz_fmt1
    376 #undef fmt1
    377 #undef fmt
    378 
    379 static const struct {
    380    const struct anv_format *formats;
    381    uint32_t n_formats;
    382 } anv_formats[] = {
    383    [0]                                       = { .formats = main_formats,
    384                                                  .n_formats = ARRAY_SIZE(main_formats), },
    385    [_VK_KHR_sampler_ycbcr_conversion_number] = { .formats = ycbcr_formats,
    386                                                  .n_formats = ARRAY_SIZE(ycbcr_formats), },
    387 };
    388 
    389 const struct anv_format *
    390 anv_get_format(VkFormat vk_format)
    391 {
    392    uint32_t enum_offset = VK_ENUM_OFFSET(vk_format);
    393    uint32_t ext_number = VK_ENUM_EXTENSION(vk_format);
    394 
    395    if (ext_number >= ARRAY_SIZE(anv_formats) ||
    396        enum_offset >= anv_formats[ext_number].n_formats)
    397       return NULL;
    398 
    399    const struct anv_format *format =
    400       &anv_formats[ext_number].formats[enum_offset];
    401    if (format->planes[0].isl_format == ISL_FORMAT_UNSUPPORTED)
    402       return NULL;
    403 
    404    return format;
    405 }
    406 
    407 /**
    408  * Exactly one bit must be set in \a aspect.
    409  */
    410 struct anv_format_plane
    411 anv_get_format_plane(const struct gen_device_info *devinfo, VkFormat vk_format,
    412                      VkImageAspectFlagBits aspect, VkImageTiling tiling)
    413 {
    414    const struct anv_format *format = anv_get_format(vk_format);
    415    const struct anv_format_plane unsupported = {
    416       .isl_format = ISL_FORMAT_UNSUPPORTED,
    417    };
    418 
    419    if (format == NULL)
    420       return unsupported;
    421 
    422    uint32_t plane = anv_image_aspect_to_plane(vk_format_aspects(vk_format), aspect);
    423    struct anv_format_plane plane_format = format->planes[plane];
    424    if (plane_format.isl_format == ISL_FORMAT_UNSUPPORTED)
    425       return unsupported;
    426 
    427    if (aspect & (VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT)) {
    428       assert(vk_format_aspects(vk_format) &
    429              (VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT));
    430       return plane_format;
    431    }
    432 
    433    assert((aspect & ~VK_IMAGE_ASPECT_ANY_COLOR_BIT_ANV) == 0);
    434 
    435    const struct isl_format_layout *isl_layout =
    436       isl_format_get_layout(plane_format.isl_format);
    437 
    438    if (tiling == VK_IMAGE_TILING_OPTIMAL &&
    439        !util_is_power_of_two(isl_layout->bpb)) {
    440       /* Tiled formats *must* be power-of-two because we need up upload
    441        * them with the render pipeline.  For 3-channel formats, we fix
    442        * this by switching them over to RGBX or RGBA formats under the
    443        * hood.
    444        */
    445       enum isl_format rgbx = isl_format_rgb_to_rgbx(plane_format.isl_format);
    446       if (rgbx != ISL_FORMAT_UNSUPPORTED &&
    447           isl_format_supports_rendering(devinfo, rgbx)) {
    448          plane_format.isl_format = rgbx;
    449       } else {
    450          plane_format.isl_format =
    451             isl_format_rgb_to_rgba(plane_format.isl_format);
    452          plane_format.swizzle = ISL_SWIZZLE(RED, GREEN, BLUE, ONE);
    453       }
    454    }
    455 
    456    /* The B4G4R4A4 format isn't available prior to Broadwell so we have to fall
    457     * back to a format with a more complex swizzle.
    458     */
    459    if (vk_format == VK_FORMAT_B4G4R4A4_UNORM_PACK16 && devinfo->gen < 8) {
    460       plane_format.isl_format = ISL_FORMAT_B4G4R4A4_UNORM;
    461       plane_format.swizzle = ISL_SWIZZLE(GREEN, RED, ALPHA, BLUE);
    462    }
    463 
    464    return plane_format;
    465 }
    466 
    467 // Format capabilities
    468 
    469 static VkFormatFeatureFlags
    470 get_image_format_features(const struct gen_device_info *devinfo,
    471                           VkFormat vk_format,
    472                           const struct anv_format *anv_format,
    473                           VkImageTiling vk_tiling)
    474 {
    475    VkFormatFeatureFlags flags = 0;
    476 
    477    if (anv_format == NULL)
    478       return 0;
    479 
    480    const VkImageAspectFlags aspects = vk_format_aspects(vk_format);
    481 
    482    if (aspects & (VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT)) {
    483       if (vk_tiling == VK_IMAGE_TILING_LINEAR)
    484          return 0;
    485 
    486       flags |= VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT;
    487 
    488       if (aspects == VK_IMAGE_ASPECT_DEPTH_BIT || devinfo->gen >= 8)
    489          flags |= VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT;
    490 
    491       flags |= VK_FORMAT_FEATURE_BLIT_SRC_BIT |
    492                VK_FORMAT_FEATURE_BLIT_DST_BIT |
    493                VK_FORMAT_FEATURE_TRANSFER_SRC_BIT_KHR |
    494                VK_FORMAT_FEATURE_TRANSFER_DST_BIT_KHR;
    495 
    496       return flags;
    497    }
    498 
    499    const struct anv_format_plane plane_format =
    500       anv_get_format_plane(devinfo, vk_format, VK_IMAGE_ASPECT_COLOR_BIT,
    501                            vk_tiling);
    502 
    503    if (plane_format.isl_format == ISL_FORMAT_UNSUPPORTED)
    504       return 0;
    505 
    506    struct anv_format_plane base_plane_format = plane_format;
    507    if (vk_tiling == VK_IMAGE_TILING_OPTIMAL) {
    508       base_plane_format = anv_get_format_plane(devinfo, vk_format,
    509                                                VK_IMAGE_ASPECT_COLOR_BIT,
    510                                                VK_IMAGE_TILING_LINEAR);
    511    }
    512 
    513    enum isl_format base_isl_format = base_plane_format.isl_format;
    514 
    515    /* ASTC textures must be in Y-tiled memory */
    516    if (vk_tiling == VK_IMAGE_TILING_LINEAR &&
    517        isl_format_get_layout(plane_format.isl_format)->txc == ISL_TXC_ASTC)
    518       return 0;
    519 
    520    if (isl_format_supports_sampling(devinfo, plane_format.isl_format)) {
    521       flags |= VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT |
    522                VK_FORMAT_FEATURE_BLIT_SRC_BIT;
    523 
    524       if (isl_format_supports_filtering(devinfo, plane_format.isl_format))
    525          flags |= VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT;
    526    }
    527 
    528    /* We can render to swizzled formats.  However, if the alpha channel is
    529     * moved, then blending won't work correctly.  The PRM tells us
    530     * straight-up not to render to such a surface.
    531     */
    532    if (isl_format_supports_rendering(devinfo, plane_format.isl_format) &&
    533        plane_format.swizzle.a == ISL_CHANNEL_SELECT_ALPHA) {
    534       flags |= VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT |
    535                VK_FORMAT_FEATURE_BLIT_DST_BIT;
    536 
    537       if (isl_format_supports_alpha_blending(devinfo, plane_format.isl_format))
    538          flags |= VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BLEND_BIT;
    539    }
    540 
    541    /* Load/store is determined based on base format.  This prevents RGB
    542     * formats from showing up as load/store capable.
    543     */
    544    if (isl_is_storage_image_format(base_isl_format))
    545       flags |= VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT;
    546 
    547    if (base_isl_format == ISL_FORMAT_R32_SINT ||
    548        base_isl_format == ISL_FORMAT_R32_UINT)
    549       flags |= VK_FORMAT_FEATURE_STORAGE_IMAGE_ATOMIC_BIT;
    550 
    551    if (flags) {
    552       flags |= VK_FORMAT_FEATURE_TRANSFER_SRC_BIT_KHR |
    553                VK_FORMAT_FEATURE_TRANSFER_DST_BIT_KHR;
    554    }
    555 
    556    /* XXX: We handle 3-channel formats by switching them out for RGBX or
    557     * RGBA formats behind-the-scenes.  This works fine for textures
    558     * because the upload process will fill in the extra channel.
    559     * We could also support it for render targets, but it will take
    560     * substantially more work and we have enough RGBX formats to handle
    561     * what most clients will want.
    562     */
    563    if (vk_tiling == VK_IMAGE_TILING_OPTIMAL &&
    564        base_isl_format != ISL_FORMAT_UNSUPPORTED &&
    565        !util_is_power_of_two(isl_format_layouts[base_isl_format].bpb) &&
    566        isl_format_rgb_to_rgbx(base_isl_format) == ISL_FORMAT_UNSUPPORTED) {
    567       flags &= ~VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT;
    568       flags &= ~VK_FORMAT_FEATURE_BLIT_DST_BIT;
    569    }
    570 
    571    if (anv_format->can_ycbcr) {
    572       /* The sampler doesn't have support for mid point when it handles YUV on
    573        * its own.
    574        */
    575       if (isl_format_is_yuv(anv_format->planes[0].isl_format)) {
    576          /* TODO: We've disabled linear implicit reconstruction with the
    577           * sampler. The failures show a slightly out of range values on the
    578           * bottom left of the sampled image.
    579           */
    580          flags |= VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT_KHR;
    581       } else {
    582          flags |= VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT_KHR |
    583                   VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT_KHR |
    584                   VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT_KHR;
    585       }
    586 
    587       /* We can support cosited chroma locations when handle planes with our
    588        * own shader snippets.
    589        */
    590       for (unsigned p = 0; p < anv_format->n_planes; p++) {
    591          if (anv_format->planes[p].denominator_scales[0] > 1 ||
    592              anv_format->planes[p].denominator_scales[1] > 1) {
    593             flags |= VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT_KHR;
    594             break;
    595          }
    596       }
    597 
    598       if (anv_format->n_planes > 1)
    599          flags |= VK_FORMAT_FEATURE_DISJOINT_BIT_KHR;
    600 
    601       const VkFormatFeatureFlags disallowed_ycbcr_image_features =
    602          VK_FORMAT_FEATURE_BLIT_SRC_BIT |
    603          VK_FORMAT_FEATURE_BLIT_DST_BIT |
    604          VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT |
    605          VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BLEND_BIT |
    606          VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT;
    607 
    608       flags &= ~disallowed_ycbcr_image_features;
    609    }
    610 
    611    return flags;
    612 }
    613 
    614 static VkFormatFeatureFlags
    615 get_buffer_format_features(const struct gen_device_info *devinfo,
    616                            VkFormat vk_format,
    617                            const struct anv_format *anv_format)
    618 {
    619    VkFormatFeatureFlags flags = 0;
    620 
    621    if (anv_format == NULL)
    622       return 0;
    623 
    624    const enum isl_format isl_format = anv_format->planes[0].isl_format;
    625 
    626    if (isl_format == ISL_FORMAT_UNSUPPORTED)
    627       return 0;
    628 
    629    if (anv_format->n_planes > 1)
    630       return 0;
    631 
    632    if (anv_format->can_ycbcr)
    633       return 0;
    634 
    635    if (vk_format_is_depth_or_stencil(vk_format))
    636       return 0;
    637 
    638    if (isl_format_supports_sampling(devinfo, isl_format) &&
    639        !isl_format_is_compressed(isl_format))
    640       flags |= VK_FORMAT_FEATURE_UNIFORM_TEXEL_BUFFER_BIT;
    641 
    642    if (isl_format_supports_vertex_fetch(devinfo, isl_format))
    643       flags |= VK_FORMAT_FEATURE_VERTEX_BUFFER_BIT;
    644 
    645    if (isl_is_storage_image_format(isl_format))
    646       flags |= VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_BIT;
    647 
    648    if (isl_format == ISL_FORMAT_R32_SINT || isl_format == ISL_FORMAT_R32_UINT)
    649       flags |= VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_ATOMIC_BIT;
    650 
    651    return flags;
    652 }
    653 
    654 void anv_GetPhysicalDeviceFormatProperties(
    655     VkPhysicalDevice                            physicalDevice,
    656     VkFormat                                    vk_format,
    657     VkFormatProperties*                         pFormatProperties)
    658 {
    659    ANV_FROM_HANDLE(anv_physical_device, physical_device, physicalDevice);
    660    const struct gen_device_info *devinfo = &physical_device->info;
    661    const struct anv_format *anv_format = anv_get_format(vk_format);
    662 
    663    *pFormatProperties = (VkFormatProperties) {
    664       .linearTilingFeatures =
    665          get_image_format_features(devinfo, vk_format, anv_format,
    666                                    VK_IMAGE_TILING_LINEAR),
    667       .optimalTilingFeatures =
    668          get_image_format_features(devinfo, vk_format, anv_format,
    669                                    VK_IMAGE_TILING_OPTIMAL),
    670       .bufferFeatures =
    671          get_buffer_format_features(devinfo, vk_format, anv_format),
    672    };
    673 }
    674 
    675 void anv_GetPhysicalDeviceFormatProperties2KHR(
    676     VkPhysicalDevice                            physicalDevice,
    677     VkFormat                                    format,
    678     VkFormatProperties2KHR*                     pFormatProperties)
    679 {
    680    anv_GetPhysicalDeviceFormatProperties(physicalDevice, format,
    681                                          &pFormatProperties->formatProperties);
    682 
    683    vk_foreach_struct(ext, pFormatProperties->pNext) {
    684       switch (ext->sType) {
    685       default:
    686          anv_debug_ignored_stype(ext->sType);
    687          break;
    688       }
    689    }
    690 }
    691 
    692 static VkResult
    693 anv_get_image_format_properties(
    694    struct anv_physical_device *physical_device,
    695    const VkPhysicalDeviceImageFormatInfo2KHR *info,
    696    VkImageFormatProperties *pImageFormatProperties,
    697    VkSamplerYcbcrConversionImageFormatPropertiesKHR *pYcbcrImageFormatProperties)
    698 {
    699    VkFormatFeatureFlags format_feature_flags;
    700    VkExtent3D maxExtent;
    701    uint32_t maxMipLevels;
    702    uint32_t maxArraySize;
    703    VkSampleCountFlags sampleCounts = VK_SAMPLE_COUNT_1_BIT;
    704    const struct gen_device_info *devinfo = &physical_device->info;
    705    const struct anv_format *format = anv_get_format(info->format);
    706 
    707    if (format == NULL)
    708       goto unsupported;
    709 
    710    format_feature_flags = get_image_format_features(devinfo, info->format,
    711                                                     format, info->tiling);
    712 
    713    switch (info->type) {
    714    default:
    715       unreachable("bad VkImageType");
    716    case VK_IMAGE_TYPE_1D:
    717       maxExtent.width = 16384;
    718       maxExtent.height = 1;
    719       maxExtent.depth = 1;
    720       maxMipLevels = 15; /* log2(maxWidth) + 1 */
    721       maxArraySize = 2048;
    722       sampleCounts = VK_SAMPLE_COUNT_1_BIT;
    723       break;
    724    case VK_IMAGE_TYPE_2D:
    725       /* FINISHME: Does this really differ for cube maps? The documentation
    726        * for RENDER_SURFACE_STATE suggests so.
    727        */
    728       maxExtent.width = 16384;
    729       maxExtent.height = 16384;
    730       maxExtent.depth = 1;
    731       maxMipLevels = 15; /* log2(maxWidth) + 1 */
    732       maxArraySize = 2048;
    733       break;
    734    case VK_IMAGE_TYPE_3D:
    735       maxExtent.width = 2048;
    736       maxExtent.height = 2048;
    737       maxExtent.depth = 2048;
    738       maxMipLevels = 12; /* log2(maxWidth) + 1 */
    739       maxArraySize = 1;
    740       break;
    741    }
    742 
    743    /* Our hardware doesn't support 1D compressed textures.
    744     *    From the SKL PRM, RENDER_SURFACE_STATE::SurfaceFormat:
    745     *    * This field cannot be a compressed (BC*, DXT*, FXT*, ETC*, EAC*) format
    746     *       if the Surface Type is SURFTYPE_1D.
    747     *    * This field cannot be ASTC format if the Surface Type is SURFTYPE_1D.
    748     */
    749    if (info->type == VK_IMAGE_TYPE_1D &&
    750        isl_format_is_compressed(format->planes[0].isl_format)) {
    751        goto unsupported;
    752    }
    753 
    754    if (info->tiling == VK_IMAGE_TILING_OPTIMAL &&
    755        info->type == VK_IMAGE_TYPE_2D &&
    756        (format_feature_flags & (VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT |
    757                                 VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT)) &&
    758        !(info->flags & VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT) &&
    759        !(info->usage & VK_IMAGE_USAGE_STORAGE_BIT)) {
    760       sampleCounts = isl_device_get_sample_counts(&physical_device->isl_dev);
    761    }
    762 
    763    if (info->usage & (VK_IMAGE_USAGE_TRANSFER_SRC_BIT |
    764                       VK_IMAGE_USAGE_TRANSFER_DST_BIT)) {
    765       /* Accept transfers on anything we can sample from or renderer to. */
    766       if (!(format_feature_flags & (VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT |
    767                                     VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT |
    768                                     VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT))) {
    769          goto unsupported;
    770       }
    771    }
    772 
    773    if (info->usage & VK_IMAGE_USAGE_SAMPLED_BIT) {
    774       if (!(format_feature_flags & VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT)) {
    775          goto unsupported;
    776       }
    777    }
    778 
    779    if (info->usage & VK_IMAGE_USAGE_STORAGE_BIT) {
    780       if (!(format_feature_flags & VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT)) {
    781          goto unsupported;
    782       }
    783    }
    784 
    785    if (info->usage & VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT) {
    786       if (!(format_feature_flags & VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT)) {
    787          goto unsupported;
    788       }
    789    }
    790 
    791    if (info->usage & VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT) {
    792       if (!(format_feature_flags & VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT)) {
    793          goto unsupported;
    794       }
    795    }
    796 
    797    if (info->usage & VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT) {
    798       /* Nothing to check. */
    799    }
    800 
    801    if (info->usage & VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT) {
    802       /* Ignore this flag because it was removed from the
    803        * provisional_I_20150910 header.
    804        */
    805    }
    806 
    807    *pImageFormatProperties = (VkImageFormatProperties) {
    808       .maxExtent = maxExtent,
    809       .maxMipLevels = maxMipLevels,
    810       .maxArrayLayers = maxArraySize,
    811       .sampleCounts = sampleCounts,
    812 
    813       /* FINISHME: Accurately calculate
    814        * VkImageFormatProperties::maxResourceSize.
    815        */
    816       .maxResourceSize = UINT32_MAX,
    817    };
    818 
    819    if (pYcbcrImageFormatProperties) {
    820       pYcbcrImageFormatProperties->combinedImageSamplerDescriptorCount =
    821          format->n_planes;
    822    }
    823 
    824    return VK_SUCCESS;
    825 
    826 unsupported:
    827    *pImageFormatProperties = (VkImageFormatProperties) {
    828       .maxExtent = { 0, 0, 0 },
    829       .maxMipLevels = 0,
    830       .maxArrayLayers = 0,
    831       .sampleCounts = 0,
    832       .maxResourceSize = 0,
    833    };
    834 
    835    return VK_ERROR_FORMAT_NOT_SUPPORTED;
    836 }
    837 
    838 VkResult anv_GetPhysicalDeviceImageFormatProperties(
    839     VkPhysicalDevice                            physicalDevice,
    840     VkFormat                                    format,
    841     VkImageType                                 type,
    842     VkImageTiling                               tiling,
    843     VkImageUsageFlags                           usage,
    844     VkImageCreateFlags                          createFlags,
    845     VkImageFormatProperties*                    pImageFormatProperties)
    846 {
    847    ANV_FROM_HANDLE(anv_physical_device, physical_device, physicalDevice);
    848 
    849    const VkPhysicalDeviceImageFormatInfo2KHR info = {
    850       .sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2_KHR,
    851       .pNext = NULL,
    852       .format = format,
    853       .type = type,
    854       .tiling = tiling,
    855       .usage = usage,
    856       .flags = createFlags,
    857    };
    858 
    859    return anv_get_image_format_properties(physical_device, &info,
    860                                           pImageFormatProperties, NULL);
    861 }
    862 
    863 static const VkExternalMemoryPropertiesKHR prime_fd_props = {
    864    /* If we can handle external, then we can both import and export it. */
    865    .externalMemoryFeatures = VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT_KHR |
    866                              VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT_KHR,
    867    /* For the moment, let's not support mixing and matching */
    868    .exportFromImportedHandleTypes =
    869       VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT_KHR |
    870       VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT,
    871    .compatibleHandleTypes =
    872       VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT_KHR |
    873       VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT,
    874 };
    875 
    876 VkResult anv_GetPhysicalDeviceImageFormatProperties2KHR(
    877     VkPhysicalDevice                            physicalDevice,
    878     const VkPhysicalDeviceImageFormatInfo2KHR*  base_info,
    879     VkImageFormatProperties2KHR*                base_props)
    880 {
    881    ANV_FROM_HANDLE(anv_physical_device, physical_device, physicalDevice);
    882    const VkPhysicalDeviceExternalImageFormatInfoKHR *external_info = NULL;
    883    VkExternalImageFormatPropertiesKHR *external_props = NULL;
    884    VkSamplerYcbcrConversionImageFormatPropertiesKHR *ycbcr_props = NULL;
    885    VkResult result;
    886 
    887    /* Extract input structs */
    888    vk_foreach_struct_const(s, base_info->pNext) {
    889       switch (s->sType) {
    890       case VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO_KHR:
    891          external_info = (const void *) s;
    892          break;
    893       default:
    894          anv_debug_ignored_stype(s->sType);
    895          break;
    896       }
    897    }
    898 
    899    /* Extract output structs */
    900    vk_foreach_struct(s, base_props->pNext) {
    901       switch (s->sType) {
    902       case VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES_KHR:
    903          external_props = (void *) s;
    904          break;
    905       case VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES_KHR:
    906          ycbcr_props = (void *) s;
    907          break;
    908       default:
    909          anv_debug_ignored_stype(s->sType);
    910          break;
    911       }
    912    }
    913 
    914    result = anv_get_image_format_properties(physical_device, base_info,
    915                &base_props->imageFormatProperties, ycbcr_props);
    916    if (result != VK_SUCCESS)
    917       goto fail;
    918 
    919    /* From the Vulkan 1.0.42 spec:
    920     *
    921     *    If handleType is 0, vkGetPhysicalDeviceImageFormatProperties2KHR will
    922     *    behave as if VkPhysicalDeviceExternalImageFormatInfoKHR was not
    923     *    present and VkExternalImageFormatPropertiesKHR will be ignored.
    924     */
    925    if (external_info && external_info->handleType != 0) {
    926       switch (external_info->handleType) {
    927       case VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT_KHR:
    928       case VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT:
    929          if (external_props)
    930             external_props->externalMemoryProperties = prime_fd_props;
    931          break;
    932       default:
    933          /* From the Vulkan 1.0.42 spec:
    934           *
    935           *    If handleType is not compatible with the [parameters] specified
    936           *    in VkPhysicalDeviceImageFormatInfo2KHR, then
    937           *    vkGetPhysicalDeviceImageFormatProperties2KHR returns
    938           *    VK_ERROR_FORMAT_NOT_SUPPORTED.
    939           */
    940          result = vk_errorf(physical_device->instance, physical_device,
    941                             VK_ERROR_FORMAT_NOT_SUPPORTED,
    942                             "unsupported VkExternalMemoryTypeFlagBitsKHR 0x%x",
    943                             external_info->handleType);
    944          goto fail;
    945       }
    946    }
    947 
    948    return VK_SUCCESS;
    949 
    950  fail:
    951    if (result == VK_ERROR_FORMAT_NOT_SUPPORTED) {
    952       /* From the Vulkan 1.0.42 spec:
    953        *
    954        *    If the combination of parameters to
    955        *    vkGetPhysicalDeviceImageFormatProperties2KHR is not supported by
    956        *    the implementation for use in vkCreateImage, then all members of
    957        *    imageFormatProperties will be filled with zero.
    958        */
    959       base_props->imageFormatProperties = (VkImageFormatProperties) {};
    960    }
    961 
    962    return result;
    963 }
    964 
    965 void anv_GetPhysicalDeviceSparseImageFormatProperties(
    966     VkPhysicalDevice                            physicalDevice,
    967     VkFormat                                    format,
    968     VkImageType                                 type,
    969     uint32_t                                    samples,
    970     VkImageUsageFlags                           usage,
    971     VkImageTiling                               tiling,
    972     uint32_t*                                   pNumProperties,
    973     VkSparseImageFormatProperties*              pProperties)
    974 {
    975    /* Sparse images are not yet supported. */
    976    *pNumProperties = 0;
    977 }
    978 
    979 void anv_GetPhysicalDeviceSparseImageFormatProperties2KHR(
    980     VkPhysicalDevice                            physicalDevice,
    981     const VkPhysicalDeviceSparseImageFormatInfo2KHR* pFormatInfo,
    982     uint32_t*                                   pPropertyCount,
    983     VkSparseImageFormatProperties2KHR*          pProperties)
    984 {
    985    /* Sparse images are not yet supported. */
    986    *pPropertyCount = 0;
    987 }
    988 
    989 void anv_GetPhysicalDeviceExternalBufferPropertiesKHR(
    990     VkPhysicalDevice                             physicalDevice,
    991     const VkPhysicalDeviceExternalBufferInfoKHR* pExternalBufferInfo,
    992     VkExternalBufferPropertiesKHR*               pExternalBufferProperties)
    993 {
    994    /* The Vulkan 1.0.42 spec says "handleType must be a valid
    995     * VkExternalMemoryHandleTypeFlagBitsKHR value" in
    996     * VkPhysicalDeviceExternalBufferInfoKHR. This differs from
    997     * VkPhysicalDeviceExternalImageFormatInfoKHR, which surprisingly permits
    998     * handleType == 0.
    999     */
   1000    assert(pExternalBufferInfo->handleType != 0);
   1001 
   1002    /* All of the current flags are for sparse which we don't support yet.
   1003     * Even when we do support it, doing sparse on external memory sounds
   1004     * sketchy.  Also, just disallowing flags is the safe option.
   1005     */
   1006    if (pExternalBufferInfo->flags)
   1007       goto unsupported;
   1008 
   1009    switch (pExternalBufferInfo->handleType) {
   1010    case VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT_KHR:
   1011    case VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT:
   1012       pExternalBufferProperties->externalMemoryProperties = prime_fd_props;
   1013       return;
   1014    default:
   1015       goto unsupported;
   1016    }
   1017 
   1018  unsupported:
   1019    pExternalBufferProperties->externalMemoryProperties =
   1020       (VkExternalMemoryPropertiesKHR) {0};
   1021 }
   1022 
   1023 VkResult anv_CreateSamplerYcbcrConversionKHR(
   1024     VkDevice                                    _device,
   1025     const VkSamplerYcbcrConversionCreateInfoKHR* pCreateInfo,
   1026     const VkAllocationCallbacks*                pAllocator,
   1027     VkSamplerYcbcrConversionKHR*                pYcbcrConversion)
   1028 {
   1029    ANV_FROM_HANDLE(anv_device, device, _device);
   1030    struct anv_ycbcr_conversion *conversion;
   1031 
   1032    assert(pCreateInfo->sType == VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO_KHR);
   1033 
   1034    conversion = vk_alloc2(&device->alloc, pAllocator, sizeof(*conversion), 8,
   1035                           VK_SYSTEM_ALLOCATION_SCOPE_OBJECT);
   1036    if (!conversion)
   1037       return vk_error(VK_ERROR_OUT_OF_HOST_MEMORY);
   1038 
   1039    memset(conversion, 0, sizeof(*conversion));
   1040 
   1041    conversion->format = anv_get_format(pCreateInfo->format);
   1042    conversion->ycbcr_model = pCreateInfo->ycbcrModel;
   1043    conversion->ycbcr_range = pCreateInfo->ycbcrRange;
   1044    conversion->mapping[0] = pCreateInfo->components.r;
   1045    conversion->mapping[1] = pCreateInfo->components.g;
   1046    conversion->mapping[2] = pCreateInfo->components.b;
   1047    conversion->mapping[3] = pCreateInfo->components.a;
   1048    conversion->chroma_offsets[0] = pCreateInfo->xChromaOffset;
   1049    conversion->chroma_offsets[1] = pCreateInfo->yChromaOffset;
   1050    conversion->chroma_filter = pCreateInfo->chromaFilter;
   1051 
   1052    bool has_chroma_subsampled = false;
   1053    for (uint32_t p = 0; p < conversion->format->n_planes; p++) {
   1054       if (conversion->format->planes[p].has_chroma &&
   1055           (conversion->format->planes[p].denominator_scales[0] > 1 ||
   1056            conversion->format->planes[p].denominator_scales[1] > 1))
   1057          has_chroma_subsampled = true;
   1058    }
   1059    conversion->chroma_reconstruction = has_chroma_subsampled &&
   1060       (conversion->chroma_offsets[0] == VK_CHROMA_LOCATION_COSITED_EVEN_KHR ||
   1061        conversion->chroma_offsets[1] == VK_CHROMA_LOCATION_COSITED_EVEN_KHR);
   1062 
   1063    *pYcbcrConversion = anv_ycbcr_conversion_to_handle(conversion);
   1064 
   1065    return VK_SUCCESS;
   1066 }
   1067 
   1068 void anv_DestroySamplerYcbcrConversionKHR(
   1069     VkDevice                                    _device,
   1070     VkSamplerYcbcrConversionKHR                 YcbcrConversion,
   1071     const VkAllocationCallbacks*                pAllocator)
   1072 {
   1073    ANV_FROM_HANDLE(anv_device, device, _device);
   1074    ANV_FROM_HANDLE(anv_ycbcr_conversion, conversion, YcbcrConversion);
   1075 
   1076    if (!conversion)
   1077       return;
   1078 
   1079    vk_free2(&device->alloc, pAllocator, conversion);
   1080 }
   1081