Compare commits
	
		
			14 Commits
		
	
	
		
			22.0-branc
			...
			chadv/revi
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | dad560939c | ||
|  | 178d22da49 | ||
|  | 5d29487a44 | ||
|  | 489b735145 | ||
|  | 64a7c1174a | ||
|  | ba9eda13a7 | ||
|  | e37012b940 | ||
|  | c20b8b9fee | ||
|  | 8045a6538b | ||
|  | 89f0c1d681 | ||
|  | 77cc49c7a4 | ||
|  | e94d1b12a5 | ||
|  | 5fb6ee5620 | ||
|  | 2772852437 | 
| @@ -134,10 +134,10 @@ get_ahw_buffer_format_properties( | |||||||
|    /* Default to OPTIMAL tiling but set to linear in case |    /* Default to OPTIMAL tiling but set to linear in case | ||||||
|     * of AHARDWAREBUFFER_USAGE_GPU_DATA_BUFFER usage. |     * of AHARDWAREBUFFER_USAGE_GPU_DATA_BUFFER usage. | ||||||
|     */ |     */ | ||||||
|    VkImageTiling tiling = VK_IMAGE_TILING_OPTIMAL; |    struct anv_tiling tiling = anv_tiling_optimal(); | ||||||
|  |  | ||||||
|    if (desc.usage & AHARDWAREBUFFER_USAGE_GPU_DATA_BUFFER) |    if (desc.usage & AHARDWAREBUFFER_USAGE_GPU_DATA_BUFFER) | ||||||
|       tiling = VK_IMAGE_TILING_LINEAR; |       tiling = anv_tiling_linear(); | ||||||
|  |  | ||||||
|    p->formatFeatures = |    p->formatFeatures = | ||||||
|       anv_get_image_format_features(&device->info, p->format, anv_format, |       anv_get_image_format_features(&device->info, p->format, anv_format, | ||||||
| @@ -472,13 +472,13 @@ anv_image_from_gralloc(VkDevice device_h, | |||||||
|    int i915_tiling = anv_gem_get_tiling(device, bo->gem_handle); |    int i915_tiling = anv_gem_get_tiling(device, bo->gem_handle); | ||||||
|    switch (i915_tiling) { |    switch (i915_tiling) { | ||||||
|    case I915_TILING_NONE: |    case I915_TILING_NONE: | ||||||
|       anv_info.isl_tiling_flags = ISL_TILING_LINEAR_BIT; |       anv_info.drm_format_mod = DRM_FORMAT_MOD_LINEAR; | ||||||
|       break; |       break; | ||||||
|    case I915_TILING_X: |    case I915_TILING_X: | ||||||
|       anv_info.isl_tiling_flags = ISL_TILING_X_BIT; |       anv_info.drm_format_mod = I915_FORMAT_MOD_X_TILED; | ||||||
|       break; |       break; | ||||||
|    case I915_TILING_Y: |    case I915_TILING_Y: | ||||||
|       anv_info.isl_tiling_flags = ISL_TILING_Y0_BIT; |       anv_info.drm_format_mod = I915_FORMAT_MOD_Y_TILED; | ||||||
|       break; |       break; | ||||||
|    case -1: |    case -1: | ||||||
|       result = vk_errorf(device->instance, device, |       result = vk_errorf(device->instance, device, | ||||||
|   | |||||||
| @@ -449,7 +449,7 @@ copy_buffer_to_image(struct anv_cmd_buffer *cmd_buffer, | |||||||
|  |  | ||||||
|       const enum isl_format buffer_format = |       const enum isl_format buffer_format = | ||||||
|          anv_get_isl_format(&cmd_buffer->device->info, anv_image->vk_format, |          anv_get_isl_format(&cmd_buffer->device->info, anv_image->vk_format, | ||||||
|                             aspect, VK_IMAGE_TILING_LINEAR); |                             aspect, anv_tiling_linear()); | ||||||
|  |  | ||||||
|       const VkExtent3D bufferImageExtent = { |       const VkExtent3D bufferImageExtent = { | ||||||
|          .width  = pRegions[r].bufferRowLength ? |          .width  = pRegions[r].bufferRowLength ? | ||||||
| @@ -1174,7 +1174,7 @@ clear_depth_stencil_attachment(struct anv_cmd_buffer *cmd_buffer, | |||||||
|       depth_format = anv_get_isl_format(&cmd_buffer->device->info, |       depth_format = anv_get_isl_format(&cmd_buffer->device->info, | ||||||
|                                         pass_att->format, |                                         pass_att->format, | ||||||
|                                         VK_IMAGE_ASPECT_DEPTH_BIT, |                                         VK_IMAGE_ASPECT_DEPTH_BIT, | ||||||
|                                         VK_IMAGE_TILING_OPTIMAL); |                                         anv_tiling_optimal()); | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    uint32_t binding_table; |    uint32_t binding_table; | ||||||
|   | |||||||
| @@ -29,7 +29,6 @@ | |||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| #include <fcntl.h> | #include <fcntl.h> | ||||||
| #include <xf86drm.h> | #include <xf86drm.h> | ||||||
| #include "drm-uapi/drm_fourcc.h" |  | ||||||
|  |  | ||||||
| #include "anv_private.h" | #include "anv_private.h" | ||||||
| #include "util/strtod.h" | #include "util/strtod.h" | ||||||
|   | |||||||
| @@ -135,6 +135,7 @@ EXTENSIONS = [ | |||||||
|     Extension('VK_EXT_global_priority',                   1, |     Extension('VK_EXT_global_priority',                   1, | ||||||
|               'device->has_context_priority'), |               'device->has_context_priority'), | ||||||
|     Extension('VK_EXT_host_query_reset',                  1, True), |     Extension('VK_EXT_host_query_reset',                  1, True), | ||||||
|  |     Extension('VK_EXT_image_drm_format_modifier',         1, True), | ||||||
|     Extension('VK_EXT_index_type_uint8',                  1, True), |     Extension('VK_EXT_index_type_uint8',                  1, True), | ||||||
|     Extension('VK_EXT_inline_uniform_block',              1, True), |     Extension('VK_EXT_inline_uniform_block',              1, True), | ||||||
|     Extension('VK_EXT_memory_budget',                     1, 'device->has_mem_available'), |     Extension('VK_EXT_memory_budget',                     1, 'device->has_mem_available'), | ||||||
|   | |||||||
| @@ -22,11 +22,29 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include "anv_private.h" | #include "anv_private.h" | ||||||
| #include "drm-uapi/drm_fourcc.h" |  | ||||||
| #include "vk_enum_to_str.h" | #include "vk_enum_to_str.h" | ||||||
| #include "vk_format_info.h" | #include "vk_format_info.h" | ||||||
| #include "vk_util.h" | #include "vk_util.h" | ||||||
|  |  | ||||||
|  | static void UNUSED | ||||||
|  | anv_tiling_validate(struct anv_tiling tiling) | ||||||
|  | { | ||||||
|  | #ifndef NDEBUG | ||||||
|  |    VkImageTiling vk = tiling.vk; | ||||||
|  |    uint64_t drm = tiling.drm_format_mod; | ||||||
|  |  | ||||||
|  |    /* In special cases, such as in WSI images, the tiling may be | ||||||
|  |     * VK_IMAGE_TILING_OPTIMAL with a valid DRM format modifier. | ||||||
|  |     */ | ||||||
|  |    assert((vk == VK_IMAGE_TILING_LINEAR && | ||||||
|  |            (drm == DRM_FORMAT_MOD_INVALID || | ||||||
|  |             drm == DRM_FORMAT_MOD_LINEAR)) || | ||||||
|  |           (vk == VK_IMAGE_TILING_OPTIMAL) || | ||||||
|  |           (vk == VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT && | ||||||
|  |            drm != DRM_FORMAT_MOD_INVALID)); | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * gcc-4 and earlier don't allow compound literals where a constant |  * gcc-4 and earlier don't allow compound literals where a constant | ||||||
|  * is required in -std=c99/gnu99 mode, so we can't use ISL_SWIZZLE() |  * is required in -std=c99/gnu99 mode, so we can't use ISL_SWIZZLE() | ||||||
| @@ -436,13 +454,29 @@ anv_get_format(VkFormat vk_format) | |||||||
|    return format; |    return format; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /** Return true if any format plane has non-power-of-two bits-per-block. */ | ||||||
|  | static bool | ||||||
|  | anv_format_has_npot_plane(const struct anv_format *anv_format) { | ||||||
|  |    for (uint32_t i = 0; i < anv_format->n_planes; ++i) { | ||||||
|  |       const struct isl_format_layout *isl_layout = | ||||||
|  |        isl_format_get_layout(anv_format->planes[i].isl_format); | ||||||
|  |  | ||||||
|  |       if (!util_is_power_of_two_or_zero(isl_layout->bpb)) | ||||||
|  |          return true; | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    return false; | ||||||
|  | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Exactly one bit must be set in \a aspect. |  * Exactly one bit must be set in \a aspect. | ||||||
|  */ |  */ | ||||||
| struct anv_format_plane | struct anv_format_plane | ||||||
| anv_get_format_plane(const struct gen_device_info *devinfo, VkFormat vk_format, | anv_get_format_plane(const struct gen_device_info *devinfo, VkFormat vk_format, | ||||||
|                      VkImageAspectFlagBits aspect, VkImageTiling tiling) |                      VkImageAspectFlagBits aspect, struct anv_tiling tiling) | ||||||
| { | { | ||||||
|  |    anv_tiling_validate(tiling); | ||||||
|  |  | ||||||
|    const struct anv_format *format = anv_get_format(vk_format); |    const struct anv_format *format = anv_get_format(vk_format); | ||||||
|    const struct anv_format_plane unsupported = { |    const struct anv_format_plane unsupported = { | ||||||
|       .isl_format = ISL_FORMAT_UNSUPPORTED, |       .isl_format = ISL_FORMAT_UNSUPPORTED, | ||||||
| @@ -459,6 +493,15 @@ anv_get_format_plane(const struct gen_device_info *devinfo, VkFormat vk_format, | |||||||
|    if (aspect & (VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT)) { |    if (aspect & (VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT)) { | ||||||
|       assert(vk_format_aspects(vk_format) & |       assert(vk_format_aspects(vk_format) & | ||||||
|              (VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT)); |              (VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT)); | ||||||
|  |  | ||||||
|  |       if (tiling.vk != VK_IMAGE_TILING_OPTIMAL) { | ||||||
|  |          /* We could support depth and stencil images with explicit | ||||||
|  |           * user-selected tiling (linear or modifier) if we wanted, but there | ||||||
|  |           * is no justification for the maintenance burden. | ||||||
|  |           */ | ||||||
|  |          return unsupported; | ||||||
|  |       } | ||||||
|  |  | ||||||
|       return plane_format; |       return plane_format; | ||||||
|    } |    } | ||||||
|  |  | ||||||
| @@ -475,13 +518,17 @@ anv_get_format_plane(const struct gen_device_info *devinfo, VkFormat vk_format, | |||||||
|        (isl_layout->bpb == 24 || isl_layout->bpb == 48)) |        (isl_layout->bpb == 24 || isl_layout->bpb == 48)) | ||||||
|       return unsupported; |       return unsupported; | ||||||
|  |  | ||||||
|    if (tiling == VK_IMAGE_TILING_OPTIMAL && |    bool rewrite_layout = false; | ||||||
|  |  | ||||||
|  |    if (!anv_tiling_is_linear(tiling) && | ||||||
|        !util_is_power_of_two_or_zero(isl_layout->bpb)) { |        !util_is_power_of_two_or_zero(isl_layout->bpb)) { | ||||||
|       /* Tiled formats *must* be power-of-two because we need up upload |       /* Tiled formats *must* be power-of-two because we need up upload | ||||||
|        * them with the render pipeline.  For 3-channel formats, we fix |        * them with the render pipeline.  For 3-channel formats, we fix | ||||||
|        * this by switching them over to RGBX or RGBA formats under the |        * this by switching them over to RGBX or RGBA formats under the | ||||||
|        * hood. |        * hood. | ||||||
|        */ |        */ | ||||||
|  |       rewrite_layout = true; | ||||||
|  |  | ||||||
|       enum isl_format rgbx = isl_format_rgb_to_rgbx(plane_format.isl_format); |       enum isl_format rgbx = isl_format_rgb_to_rgbx(plane_format.isl_format); | ||||||
|       if (rgbx != ISL_FORMAT_UNSUPPORTED && |       if (rgbx != ISL_FORMAT_UNSUPPORTED && | ||||||
|           isl_format_supports_rendering(devinfo, rgbx)) { |           isl_format_supports_rendering(devinfo, rgbx)) { | ||||||
| @@ -497,10 +544,19 @@ anv_get_format_plane(const struct gen_device_info *devinfo, VkFormat vk_format, | |||||||
|     * back to a format with a more complex swizzle. |     * back to a format with a more complex swizzle. | ||||||
|     */ |     */ | ||||||
|    if (vk_format == VK_FORMAT_B4G4R4A4_UNORM_PACK16 && devinfo->gen < 8) { |    if (vk_format == VK_FORMAT_B4G4R4A4_UNORM_PACK16 && devinfo->gen < 8) { | ||||||
|  |       rewrite_layout = true; | ||||||
|       plane_format.isl_format = ISL_FORMAT_B4G4R4A4_UNORM; |       plane_format.isl_format = ISL_FORMAT_B4G4R4A4_UNORM; | ||||||
|       plane_format.swizzle = ISL_SWIZZLE(GREEN, RED, ALPHA, BLUE); |       plane_format.swizzle = ISL_SWIZZLE(GREEN, RED, ALPHA, BLUE); | ||||||
|    } |    } | ||||||
|  |  | ||||||
|  |    /* For VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT, the image's physical layout | ||||||
|  |     * must not differ from its nominal layout in the Vulkan API. | ||||||
|  |     */ | ||||||
|  |    if (tiling.vk == VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT && | ||||||
|  |        rewrite_layout) { | ||||||
|  |       return unsupported; | ||||||
|  |    } | ||||||
|  |  | ||||||
|    return plane_format; |    return plane_format; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -510,18 +566,25 @@ VkFormatFeatureFlags | |||||||
| anv_get_image_format_features(const struct gen_device_info *devinfo, | anv_get_image_format_features(const struct gen_device_info *devinfo, | ||||||
|                               VkFormat vk_format, |                               VkFormat vk_format, | ||||||
|                               const struct anv_format *anv_format, |                               const struct anv_format *anv_format, | ||||||
|                               VkImageTiling vk_tiling) |                               struct anv_tiling tiling) | ||||||
| { | { | ||||||
|    VkFormatFeatureFlags flags = 0; |    VkFormatFeatureFlags flags = 0; | ||||||
|  |  | ||||||
|    if (anv_format == NULL) |    if (anv_format == NULL) | ||||||
|       return 0; |       return 0; | ||||||
|  |  | ||||||
|  |    anv_tiling_validate(tiling); | ||||||
|  |  | ||||||
|    const VkImageAspectFlags aspects = vk_format_aspects(vk_format); |    const VkImageAspectFlags aspects = vk_format_aspects(vk_format); | ||||||
|  |  | ||||||
|    if (aspects & (VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT)) { |    if (aspects & (VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT)) { | ||||||
|       if (vk_tiling == VK_IMAGE_TILING_LINEAR) |       if (tiling.vk != VK_IMAGE_TILING_OPTIMAL) { | ||||||
|  |          /* We could support depth and stencil images with explicit | ||||||
|  |           * user-selected tiling (linear or modifier) if we wanted, but there | ||||||
|  |           * is no justification for the maintenance burden. | ||||||
|  |           */ | ||||||
|          return 0; |          return 0; | ||||||
|  |       } | ||||||
|  |  | ||||||
|       flags |= VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT | |       flags |= VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT | | ||||||
|                VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT | |                VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT | | ||||||
| @@ -538,32 +601,36 @@ anv_get_image_format_features(const struct gen_device_info *devinfo, | |||||||
|  |  | ||||||
|    const struct anv_format_plane plane_format = |    const struct anv_format_plane plane_format = | ||||||
|       anv_get_format_plane(devinfo, vk_format, VK_IMAGE_ASPECT_COLOR_BIT, |       anv_get_format_plane(devinfo, vk_format, VK_IMAGE_ASPECT_COLOR_BIT, | ||||||
|                            vk_tiling); |                            tiling); | ||||||
|  |  | ||||||
|    if (plane_format.isl_format == ISL_FORMAT_UNSUPPORTED) |    if (plane_format.isl_format == ISL_FORMAT_UNSUPPORTED) | ||||||
|       return 0; |       return 0; | ||||||
|  |  | ||||||
|    struct anv_format_plane base_plane_format = plane_format; |    struct anv_format_plane base_plane_format = plane_format; | ||||||
|    if (vk_tiling == VK_IMAGE_TILING_OPTIMAL) { |    if (tiling.vk == VK_IMAGE_TILING_OPTIMAL) { | ||||||
|       base_plane_format = anv_get_format_plane(devinfo, vk_format, |       base_plane_format = anv_get_format_plane(devinfo, vk_format, | ||||||
|                                                VK_IMAGE_ASPECT_COLOR_BIT, |                                                VK_IMAGE_ASPECT_COLOR_BIT, | ||||||
|                                                VK_IMAGE_TILING_LINEAR); |                                                anv_tiling_linear()); | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    enum isl_format base_isl_format = base_plane_format.isl_format; |    enum isl_format base_isl_format = base_plane_format.isl_format; | ||||||
|  |  | ||||||
|    /* ASTC textures must be in Y-tiled memory */ |    if (isl_format_get_layout(plane_format.isl_format)->txc == ISL_TXC_ASTC) { | ||||||
|    if (vk_tiling == VK_IMAGE_TILING_LINEAR && |       /* ASTC requires nasty workarounds on BSW so we just disable it for now. | ||||||
|        isl_format_get_layout(plane_format.isl_format)->txc == ISL_TXC_ASTC) |        * | ||||||
|       return 0; |        * TODO: Figure out the ASTC workarounds and re-enable on BSW. | ||||||
|  |        */ | ||||||
|  |       if (devinfo->gen < 9) | ||||||
|  |          return 0; | ||||||
|  |  | ||||||
|    /* ASTC requires nasty workarounds on BSW so we just disable it for now. |       /* ASTC must be Y-tiled without CCS. */ | ||||||
|     * |       if (tiling.drm_format_mod == DRM_FORMAT_MOD_INVALID) { | ||||||
|     * TODO: Figure out the ASTC workarounds and re-enable on BSW. |          if (tiling.vk != VK_IMAGE_TILING_OPTIMAL) | ||||||
|     */ |             return 0; | ||||||
|    if (devinfo->gen < 9 && |       } else if (tiling.drm_format_mod != I915_FORMAT_MOD_Y_TILED) { | ||||||
|        isl_format_get_layout(plane_format.isl_format)->txc == ISL_TXC_ASTC) |          return 0; | ||||||
|       return 0; |       } | ||||||
|  |    } | ||||||
|  |  | ||||||
|    if (isl_format_supports_sampling(devinfo, plane_format.isl_format)) { |    if (isl_format_supports_sampling(devinfo, plane_format.isl_format)) { | ||||||
|       flags |= VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT; |       flags |= VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT; | ||||||
| @@ -611,7 +678,7 @@ anv_get_image_format_features(const struct gen_device_info *devinfo, | |||||||
|     * substantially more work and we have enough RGBX formats to handle |     * substantially more work and we have enough RGBX formats to handle | ||||||
|     * what most clients will want. |     * what most clients will want. | ||||||
|     */ |     */ | ||||||
|    if (vk_tiling == VK_IMAGE_TILING_OPTIMAL && |    if (!anv_tiling_is_linear(tiling) && | ||||||
|        base_isl_format != ISL_FORMAT_UNSUPPORTED && |        base_isl_format != ISL_FORMAT_UNSUPPORTED && | ||||||
|        !util_is_power_of_two_or_zero(isl_format_layouts[base_isl_format].bpb) && |        !util_is_power_of_two_or_zero(isl_format_layouts[base_isl_format].bpb) && | ||||||
|        isl_format_rgb_to_rgbx(base_isl_format) == ISL_FORMAT_UNSUPPORTED) { |        isl_format_rgb_to_rgbx(base_isl_format) == ISL_FORMAT_UNSUPPORTED) { | ||||||
| @@ -659,6 +726,16 @@ anv_get_image_format_features(const struct gen_device_info *devinfo, | |||||||
|       flags &= ~disallowed_ycbcr_image_features; |       flags &= ~disallowed_ycbcr_image_features; | ||||||
|    } |    } | ||||||
|  |  | ||||||
|  |    if (tiling.vk == VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT && | ||||||
|  |        isl_drm_modifier_has_aux(tiling.drm_format_mod)) { | ||||||
|  |       /* Defensively reject DISJOINT because the placement of the aux surface | ||||||
|  |        * might be constrained by hardware. For example, on gen9 the display | ||||||
|  |        * engine requires the CCS, if it exists, to reside at a higher physical | ||||||
|  |        * address than the primary surface. | ||||||
|  |        */ | ||||||
|  |       flags &= ~VK_FORMAT_FEATURE_DISJOINT_BIT; | ||||||
|  |    } | ||||||
|  |  | ||||||
|    return flags; |    return flags; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -703,46 +780,109 @@ get_buffer_format_features(const struct gen_device_info *devinfo, | |||||||
| } | } | ||||||
|  |  | ||||||
| static void | static void | ||||||
| get_wsi_format_modifier_properties_list(const struct anv_physical_device *physical_device, | get_drm_format_modifier_properties_list(const struct anv_physical_device *physical_device, | ||||||
|                                         VkFormat vk_format, |                                         VkFormat vk_format, | ||||||
|                                         struct wsi_format_modifier_properties_list *list) |                                         VkDrmFormatModifierPropertiesListEXT *list) | ||||||
| { | { | ||||||
|  |    const struct gen_device_info *devinfo = &physical_device->info; | ||||||
|    const struct anv_format *anv_format = anv_get_format(vk_format); |    const struct anv_format *anv_format = anv_get_format(vk_format); | ||||||
|  |    bool has_npot_plane = anv_format_has_npot_plane(anv_format); | ||||||
|  |  | ||||||
|    VK_OUTARRAY_MAKE(out, list->modifier_properties, &list->modifier_count); |    VK_OUTARRAY_MAKE(out, list->pDrmFormatModifierProperties, | ||||||
|  |                     &list->drmFormatModifierCount); | ||||||
|  |  | ||||||
|    /* This is a simplified list where all the modifiers are available */ |    const uint64_t mods[] = { | ||||||
|    assert(vk_format == VK_FORMAT_B8G8R8_SRGB || |  | ||||||
|           vk_format == VK_FORMAT_B8G8R8_UNORM || |  | ||||||
|           vk_format == VK_FORMAT_B8G8R8A8_SRGB || |  | ||||||
|           vk_format == VK_FORMAT_B8G8R8A8_UNORM); |  | ||||||
|  |  | ||||||
|    uint64_t modifiers[] = { |  | ||||||
|       DRM_FORMAT_MOD_LINEAR, |       DRM_FORMAT_MOD_LINEAR, | ||||||
|       I915_FORMAT_MOD_X_TILED, |       I915_FORMAT_MOD_X_TILED, | ||||||
|       I915_FORMAT_MOD_Y_TILED, |       I915_FORMAT_MOD_Y_TILED, | ||||||
|       I915_FORMAT_MOD_Y_TILED_CCS, |       I915_FORMAT_MOD_Y_TILED_CCS, | ||||||
|    }; |    }; | ||||||
|  |  | ||||||
|    for (uint32_t i = 0; i < ARRAY_SIZE(modifiers); i++) { |    for (uint32_t i = 0; i < ARRAY_SIZE(mods); i++) { | ||||||
|  |       uint64_t mod = mods[i]; | ||||||
|  |  | ||||||
|       const struct isl_drm_modifier_info *mod_info = |       const struct isl_drm_modifier_info *mod_info = | ||||||
|          isl_drm_modifier_get_info(modifiers[i]); |          isl_drm_modifier_get_info(mod); | ||||||
|  |  | ||||||
|  |       /* Tiled formats must be power-of-two because we implement transfers | ||||||
|  |        * with the render pipeline. | ||||||
|  |        * | ||||||
|  |        * Maybe we could support tiled non-power-of-two formats if we limited | ||||||
|  |        * drmFormatModifierTilingFeatures to VK_FORMAT_FEATURE_SAMPLED_*, but | ||||||
|  |        * it's not worth the maintenance and testing burden. | ||||||
|  |        */ | ||||||
|  |       if (has_npot_plane && mod != DRM_FORMAT_MOD_LINEAR ) | ||||||
|  |          continue; | ||||||
|  |  | ||||||
|       if (mod_info->aux_usage == ISL_AUX_USAGE_CCS_E && |       if (mod_info->aux_usage == ISL_AUX_USAGE_CCS_E && | ||||||
|           !isl_format_supports_ccs_e(&physical_device->info, |           !isl_format_supports_ccs_e(&physical_device->info, | ||||||
|                                      anv_format->planes[0].isl_format)) |                                      anv_format->planes[0].isl_format)) | ||||||
|          continue; |          continue; | ||||||
|  |  | ||||||
|  |       VkFormatFeatureFlags format_features = | ||||||
|  |          anv_get_image_format_features(devinfo, vk_format, anv_format, | ||||||
|  |                                        anv_tiling_drm(mod)); | ||||||
|  |       if (!format_features) | ||||||
|  |          continue; | ||||||
|  |  | ||||||
|       vk_outarray_append(&out, mod_props) { |       vk_outarray_append(&out, mod_props) { | ||||||
|          mod_props->modifier = modifiers[i]; |          mod_props->drmFormatModifier = mod; | ||||||
|          if (isl_drm_modifier_has_aux(modifiers[i])) |          mod_props->drmFormatModifierPlaneCount = anv_format->n_planes; | ||||||
|             mod_props->modifier_plane_count = 2; |          mod_props->drmFormatModifierTilingFeatures = format_features; | ||||||
|          else |  | ||||||
|             mod_props->modifier_plane_count = anv_format->n_planes; |          if (mod_info->aux_usage != ISL_AUX_USAGE_NONE) { | ||||||
|  |             mod_props->drmFormatModifierPlaneCount += 1; | ||||||
|  |          } | ||||||
|       } |       } | ||||||
|    } |    } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | static void | ||||||
|  | get_wsi_format_modifier_properties_list(const struct anv_physical_device *physical_device, | ||||||
|  |                                         VkFormat vk_format, | ||||||
|  |                                         struct wsi_format_modifier_properties_list *wsi_list) | ||||||
|  | { | ||||||
|  |    /* This is a simplified list where all the modifiers are available */ | ||||||
|  |    assert(vk_format == VK_FORMAT_B8G8R8_SRGB || | ||||||
|  |           vk_format == VK_FORMAT_B8G8R8_UNORM || | ||||||
|  |           vk_format == VK_FORMAT_B8G8R8A8_SRGB || | ||||||
|  |           vk_format == VK_FORMAT_B8G8R8A8_UNORM); | ||||||
|  |  | ||||||
|  |    /* Implement by proxying to VK_EXT_image_drm_format_modifier. */ | ||||||
|  |    VkDrmFormatModifierPropertiesListEXT drm_list = { | ||||||
|  |       .sType = VK_STRUCTURE_TYPE_DRM_FORMAT_MODIFIER_PROPERTIES_LIST_EXT, | ||||||
|  |       .drmFormatModifierCount = wsi_list->modifier_count, | ||||||
|  |       .pDrmFormatModifierProperties = NULL, | ||||||
|  |    }; | ||||||
|  |  | ||||||
|  |    if (wsi_list->modifier_properties != NULL && | ||||||
|  |        wsi_list->modifier_count > 0) { | ||||||
|  |       /* Allocate temporary VkDrmFormatModifierPropertiesEXT array. */ | ||||||
|  |       size_t size = sizeof(drm_list.pDrmFormatModifierProperties[0]); | ||||||
|  |       if (__builtin_mul_overflow(size, wsi_list->modifier_count, &size)) | ||||||
|  |          abort(); | ||||||
|  |       drm_list.pDrmFormatModifierProperties = alloca(size); | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    get_drm_format_modifier_properties_list(physical_device, vk_format, | ||||||
|  |                                            &drm_list); | ||||||
|  |  | ||||||
|  |    /* Copy results from drm_list to wsi_list. */ | ||||||
|  |    if (wsi_list->modifier_properties != NULL) { | ||||||
|  |       assert(drm_list.drmFormatModifierCount <= wsi_list->modifier_count); | ||||||
|  |  | ||||||
|  |       for (uint32_t i = 0; i < drm_list.drmFormatModifierCount; ++i) { | ||||||
|  |          struct wsi_format_modifier_properties *wsi_props = &wsi_list->modifier_properties[i]; | ||||||
|  |          VkDrmFormatModifierPropertiesEXT *drm_props = &drm_list.pDrmFormatModifierProperties[i]; | ||||||
|  |  | ||||||
|  |          wsi_props->modifier = drm_props->drmFormatModifier; | ||||||
|  |          wsi_props->modifier_plane_count = drm_props->drmFormatModifierPlaneCount; | ||||||
|  |       } | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    wsi_list->modifier_count = drm_list.drmFormatModifierCount; | ||||||
|  | } | ||||||
|  |  | ||||||
| void anv_GetPhysicalDeviceFormatProperties( | void anv_GetPhysicalDeviceFormatProperties( | ||||||
|     VkPhysicalDevice                            physicalDevice, |     VkPhysicalDevice                            physicalDevice, | ||||||
|     VkFormat                                    vk_format, |     VkFormat                                    vk_format, | ||||||
| @@ -755,10 +895,10 @@ void anv_GetPhysicalDeviceFormatProperties( | |||||||
|    *pFormatProperties = (VkFormatProperties) { |    *pFormatProperties = (VkFormatProperties) { | ||||||
|       .linearTilingFeatures = |       .linearTilingFeatures = | ||||||
|          anv_get_image_format_features(devinfo, vk_format, anv_format, |          anv_get_image_format_features(devinfo, vk_format, anv_format, | ||||||
|                                        VK_IMAGE_TILING_LINEAR), |                                        anv_tiling_linear()), | ||||||
|       .optimalTilingFeatures = |       .optimalTilingFeatures = | ||||||
|          anv_get_image_format_features(devinfo, vk_format, anv_format, |          anv_get_image_format_features(devinfo, vk_format, anv_format, | ||||||
|                                        VK_IMAGE_TILING_OPTIMAL), |                                        anv_tiling_optimal()), | ||||||
|       .bufferFeatures = |       .bufferFeatures = | ||||||
|          get_buffer_format_features(devinfo, vk_format, anv_format), |          get_buffer_format_features(devinfo, vk_format, anv_format), | ||||||
|    }; |    }; | ||||||
| @@ -780,6 +920,10 @@ void anv_GetPhysicalDeviceFormatProperties2( | |||||||
|          get_wsi_format_modifier_properties_list(physical_device, format, |          get_wsi_format_modifier_properties_list(physical_device, format, | ||||||
|                                                  (void *)ext); |                                                  (void *)ext); | ||||||
|          break; |          break; | ||||||
|  |       case VK_STRUCTURE_TYPE_DRM_FORMAT_MODIFIER_PROPERTIES_LIST_EXT: | ||||||
|  |          get_drm_format_modifier_properties_list(physical_device, format, | ||||||
|  |                                                  (void *)ext); | ||||||
|  |          break; | ||||||
|       default: |       default: | ||||||
|          anv_debug_ignored_stype(ext->sType); |          anv_debug_ignored_stype(ext->sType); | ||||||
|          break; |          break; | ||||||
| @@ -790,7 +934,8 @@ void anv_GetPhysicalDeviceFormatProperties2( | |||||||
| static VkResult | static VkResult | ||||||
| anv_get_image_format_properties( | anv_get_image_format_properties( | ||||||
|    struct anv_physical_device *physical_device, |    struct anv_physical_device *physical_device, | ||||||
|    const VkPhysicalDeviceImageFormatInfo2 *info, |    const VkPhysicalDeviceImageFormatInfo2 *base_info, | ||||||
|  |    const VkPhysicalDeviceImageDrmFormatModifierInfoEXT *drm_info, | ||||||
|    VkImageFormatProperties *pImageFormatProperties, |    VkImageFormatProperties *pImageFormatProperties, | ||||||
|    VkSamplerYcbcrConversionImageFormatProperties *pYcbcrImageFormatProperties) |    VkSamplerYcbcrConversionImageFormatProperties *pYcbcrImageFormatProperties) | ||||||
| { | { | ||||||
| @@ -799,20 +944,38 @@ anv_get_image_format_properties( | |||||||
|    uint32_t maxMipLevels; |    uint32_t maxMipLevels; | ||||||
|    uint32_t maxArraySize; |    uint32_t maxArraySize; | ||||||
|    VkSampleCountFlags sampleCounts = VK_SAMPLE_COUNT_1_BIT; |    VkSampleCountFlags sampleCounts = VK_SAMPLE_COUNT_1_BIT; | ||||||
|  |  | ||||||
|  |    struct anv_instance *instance = physical_device->instance; | ||||||
|    const struct gen_device_info *devinfo = &physical_device->info; |    const struct gen_device_info *devinfo = &physical_device->info; | ||||||
|    const struct anv_format *format = anv_get_format(info->format); |    const struct anv_format *format = anv_get_format(base_info->format); | ||||||
|  |  | ||||||
|    if (format == NULL) |    if (format == NULL) | ||||||
|       goto unsupported; |       goto unsupported; | ||||||
|  |  | ||||||
|    assert(format->vk_format == info->format); |    assert(format->vk_format == base_info->format); | ||||||
|    format_feature_flags = anv_get_image_format_features(devinfo, info->format, |  | ||||||
|                                                         format, info->tiling); |  | ||||||
|  |  | ||||||
|    switch (info->type) { |    struct anv_tiling tiling = { | ||||||
|  |       .vk = base_info->tiling, | ||||||
|  |       .drm_format_mod = drm_info ? | ||||||
|  |          drm_info->drmFormatModifier : DRM_FORMAT_MOD_INVALID, | ||||||
|  |    }; | ||||||
|  |  | ||||||
|  |    format_feature_flags = anv_get_image_format_features(devinfo, base_info->format, | ||||||
|  |                                                         format, tiling); | ||||||
|  |  | ||||||
|  |    switch (base_info->type) { | ||||||
|    default: |    default: | ||||||
|       unreachable("bad VkImageType"); |       unreachable("bad VkImageType"); | ||||||
|    case VK_IMAGE_TYPE_1D: |    case VK_IMAGE_TYPE_1D: | ||||||
|  |       if (base_info->tiling == VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT) { | ||||||
|  |          /* Reject to avoid maintenance and testing burden. */ | ||||||
|  |          vk_errorf(instance, physical_device, | ||||||
|  |                    VK_ERROR_FORMAT_NOT_SUPPORTED, | ||||||
|  |                    "VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT " | ||||||
|  |                    "not supported for VK_IMAGE_TYPE_1D"); | ||||||
|  |          goto unsupported; | ||||||
|  |       } | ||||||
|  |  | ||||||
|       maxExtent.width = 16384; |       maxExtent.width = 16384; | ||||||
|       maxExtent.height = 1; |       maxExtent.height = 1; | ||||||
|       maxExtent.depth = 1; |       maxExtent.depth = 1; | ||||||
| @@ -829,8 +992,50 @@ anv_get_image_format_properties( | |||||||
|       maxExtent.depth = 1; |       maxExtent.depth = 1; | ||||||
|       maxMipLevels = 15; /* log2(maxWidth) + 1 */ |       maxMipLevels = 15; /* log2(maxWidth) + 1 */ | ||||||
|       maxArraySize = 2048; |       maxArraySize = 2048; | ||||||
|  |  | ||||||
|  |       if (base_info->tiling == VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT) { | ||||||
|  |          /* Reject mipmapped and array images because: | ||||||
|  |           * | ||||||
|  |           *   - We wish to avoid unnecessary maintenance burden. | ||||||
|  |           * | ||||||
|  |           *   - VK_EXT_image_drm_format_modifier provides sufficient API for | ||||||
|  |           *     exporting a mipmapped and/or array image (create with | ||||||
|  |           *     VkImageDrmFormatModifierListCreateInfoEXT and query layout | ||||||
|  |           *     with vkGetImageSubresourceLayout), but provides no API for | ||||||
|  |           *     *importing* such an image. | ||||||
|  |           *     (VkImageDrmFormatModifierExplicitCreateInfoEXT is too simple). | ||||||
|  |           *     If vkGetPhysicalDeviceImageFormatProperties2 succeeds, the app | ||||||
|  |           *     may reasonably expect the driver to support both import and | ||||||
|  |           *     export. | ||||||
|  |           * | ||||||
|  |           *   - For Intel-specific modifiers, Intel could work around the | ||||||
|  |           *     limitations of VkImageDrmFormatModifierExplicitCreateInfoEXT | ||||||
|  |           *     by defining ABI that hardcodes the layout of miplevels and | ||||||
|  |           *     array layers. But Intel has not yet defined such an ABI. | ||||||
|  |           */ | ||||||
|  |          maxMipLevels = 1; | ||||||
|  |          maxArraySize = 1; | ||||||
|  |  | ||||||
|  |          if (base_info->flags & VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT) { | ||||||
|  |             /* Reject for the same reasons that we reject array images. */ | ||||||
|  |             vk_errorf(instance, physical_device, | ||||||
|  |                       VK_ERROR_FORMAT_NOT_SUPPORTED, | ||||||
|  |                       "VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT " | ||||||
|  |                       "not supported for VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT"); | ||||||
|  |             goto unsupported; | ||||||
|  |          } | ||||||
|  |       } | ||||||
|       break; |       break; | ||||||
|    case VK_IMAGE_TYPE_3D: |    case VK_IMAGE_TYPE_3D: | ||||||
|  |       if (base_info->tiling == VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT) { | ||||||
|  |          /* Reject to avoid maintenance and testing burden. */ | ||||||
|  |          vk_errorf(instance, physical_device, | ||||||
|  |                    VK_ERROR_FORMAT_NOT_SUPPORTED, | ||||||
|  |                    "VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT " | ||||||
|  |                    "not supported for VK_IMAGE_TYPE_3D"); | ||||||
|  |          goto unsupported; | ||||||
|  |       } | ||||||
|  |  | ||||||
|       maxExtent.width = 2048; |       maxExtent.width = 2048; | ||||||
|       maxExtent.height = 2048; |       maxExtent.height = 2048; | ||||||
|       maxExtent.depth = 2048; |       maxExtent.depth = 2048; | ||||||
| @@ -845,22 +1050,38 @@ anv_get_image_format_properties( | |||||||
|     *       if the Surface Type is SURFTYPE_1D. |     *       if the Surface Type is SURFTYPE_1D. | ||||||
|     *    * This field cannot be ASTC format if the Surface Type is SURFTYPE_1D. |     *    * This field cannot be ASTC format if the Surface Type is SURFTYPE_1D. | ||||||
|     */ |     */ | ||||||
|    if (info->type == VK_IMAGE_TYPE_1D && |    if (base_info->type == VK_IMAGE_TYPE_1D && | ||||||
|        isl_format_is_compressed(format->planes[0].isl_format)) { |        isl_format_is_compressed(format->planes[0].isl_format)) { | ||||||
|        goto unsupported; |        goto unsupported; | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    if (info->tiling == VK_IMAGE_TILING_OPTIMAL && |    if (base_info->tiling == VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT && | ||||||
|        info->type == VK_IMAGE_TYPE_2D && |        (base_info->flags & VK_IMAGE_CREATE_DISJOINT_BIT) && | ||||||
|  |        isl_drm_modifier_has_aux(drm_info->drmFormatModifier)) { | ||||||
|  |       /* Defensively reject DISJOINT because the placement of the aux surface | ||||||
|  |        * might be constrained by hardware. For example, on gen9 the display | ||||||
|  |        * engine requires the CCS, if it exists, to reside at a higher physical | ||||||
|  |        * address than the primary surface. | ||||||
|  |        */ | ||||||
|  |       vk_errorf(instance, physical_device, | ||||||
|  |                 VK_ERROR_FORMAT_NOT_SUPPORTED, | ||||||
|  |                 "drmFormatModifier(0x%"PRIx64") " | ||||||
|  |                 "not supported for VK_IMAGE_CREATE_DISJOINT_BIT", | ||||||
|  |                 drm_info->drmFormatModifier); | ||||||
|  |       goto unsupported; | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    if (base_info->tiling == VK_IMAGE_TILING_OPTIMAL && | ||||||
|  |        base_info->type == VK_IMAGE_TYPE_2D && | ||||||
|        (format_feature_flags & (VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT | |        (format_feature_flags & (VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT | | ||||||
|                                 VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT)) && |                                 VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT)) && | ||||||
|        !(info->flags & VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT) && |        !(base_info->flags & VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT) && | ||||||
|        !(info->usage & VK_IMAGE_USAGE_STORAGE_BIT)) { |        !(base_info->usage & VK_IMAGE_USAGE_STORAGE_BIT)) { | ||||||
|       sampleCounts = isl_device_get_sample_counts(&physical_device->isl_dev); |       sampleCounts = isl_device_get_sample_counts(&physical_device->isl_dev); | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    if (info->usage & (VK_IMAGE_USAGE_TRANSFER_SRC_BIT | |    if (base_info->usage & (VK_IMAGE_USAGE_TRANSFER_SRC_BIT | | ||||||
|                       VK_IMAGE_USAGE_TRANSFER_DST_BIT)) { |                            VK_IMAGE_USAGE_TRANSFER_DST_BIT)) { | ||||||
|       /* Accept transfers on anything we can sample from or renderer to. */ |       /* Accept transfers on anything we can sample from or renderer to. */ | ||||||
|       if (!(format_feature_flags & (VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT | |       if (!(format_feature_flags & (VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT | | ||||||
|                                     VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT | |                                     VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT | | ||||||
| @@ -869,35 +1090,35 @@ anv_get_image_format_properties( | |||||||
|       } |       } | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    if (info->usage & VK_IMAGE_USAGE_SAMPLED_BIT) { |    if (base_info->usage & VK_IMAGE_USAGE_SAMPLED_BIT) { | ||||||
|       if (!(format_feature_flags & VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT)) { |       if (!(format_feature_flags & VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT)) { | ||||||
|          goto unsupported; |          goto unsupported; | ||||||
|       } |       } | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    if (info->usage & VK_IMAGE_USAGE_STORAGE_BIT) { |    if (base_info->usage & VK_IMAGE_USAGE_STORAGE_BIT) { | ||||||
|       if (!(format_feature_flags & VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT)) { |       if (!(format_feature_flags & VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT)) { | ||||||
|          goto unsupported; |          goto unsupported; | ||||||
|       } |       } | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    if (info->usage & VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT) { |    if (base_info->usage & VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT) { | ||||||
|       if (!(format_feature_flags & VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT)) { |       if (!(format_feature_flags & VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT)) { | ||||||
|          goto unsupported; |          goto unsupported; | ||||||
|       } |       } | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    if (info->usage & VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT) { |    if (base_info->usage & VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT) { | ||||||
|       if (!(format_feature_flags & VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT)) { |       if (!(format_feature_flags & VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT)) { | ||||||
|          goto unsupported; |          goto unsupported; | ||||||
|       } |       } | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    if (info->usage & VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT) { |    if (base_info->usage & VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT) { | ||||||
|       /* Nothing to check. */ |       /* Nothing to check. */ | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    if (info->usage & VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT) { |    if (base_info->usage & VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT) { | ||||||
|       /* Ignore this flag because it was removed from the |       /* Ignore this flag because it was removed from the | ||||||
|        * provisional_I_20150910 header. |        * provisional_I_20150910 header. | ||||||
|        */ |        */ | ||||||
| @@ -968,7 +1189,7 @@ VkResult anv_GetPhysicalDeviceImageFormatProperties( | |||||||
|       .flags = createFlags, |       .flags = createFlags, | ||||||
|    }; |    }; | ||||||
|  |  | ||||||
|    return anv_get_image_format_properties(physical_device, &info, |    return anv_get_image_format_properties(physical_device, &info, NULL, | ||||||
|                                           pImageFormatProperties, NULL); |                                           pImageFormatProperties, NULL); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1019,6 +1240,7 @@ VkResult anv_GetPhysicalDeviceImageFormatProperties2( | |||||||
| { | { | ||||||
|    ANV_FROM_HANDLE(anv_physical_device, physical_device, physicalDevice); |    ANV_FROM_HANDLE(anv_physical_device, physical_device, physicalDevice); | ||||||
|    const VkPhysicalDeviceExternalImageFormatInfo *external_info = NULL; |    const VkPhysicalDeviceExternalImageFormatInfo *external_info = NULL; | ||||||
|  |    const VkPhysicalDeviceImageDrmFormatModifierInfoEXT *drm_info = NULL; | ||||||
|    VkExternalImageFormatProperties *external_props = NULL; |    VkExternalImageFormatProperties *external_props = NULL; | ||||||
|    VkSamplerYcbcrConversionImageFormatProperties *ycbcr_props = NULL; |    VkSamplerYcbcrConversionImageFormatProperties *ycbcr_props = NULL; | ||||||
|    struct VkAndroidHardwareBufferUsageANDROID *android_usage = NULL; |    struct VkAndroidHardwareBufferUsageANDROID *android_usage = NULL; | ||||||
| @@ -1030,6 +1252,9 @@ VkResult anv_GetPhysicalDeviceImageFormatProperties2( | |||||||
|       case VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO: |       case VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO: | ||||||
|          external_info = (const void *) s; |          external_info = (const void *) s; | ||||||
|          break; |          break; | ||||||
|  |       case VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_DRM_FORMAT_MODIFIER_INFO_EXT: | ||||||
|  |          drm_info = (const void *) s; | ||||||
|  |          break; | ||||||
|       case VK_STRUCTURE_TYPE_IMAGE_STENCIL_USAGE_CREATE_INFO_EXT: |       case VK_STRUCTURE_TYPE_IMAGE_STENCIL_USAGE_CREATE_INFO_EXT: | ||||||
|          /* Ignore but don't warn */ |          /* Ignore but don't warn */ | ||||||
|          break; |          break; | ||||||
| @@ -1057,7 +1282,7 @@ VkResult anv_GetPhysicalDeviceImageFormatProperties2( | |||||||
|       } |       } | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    result = anv_get_image_format_properties(physical_device, base_info, |    result = anv_get_image_format_properties(physical_device, base_info, drm_info, | ||||||
|                &base_props->imageFormatProperties, ycbcr_props); |                &base_props->imageFormatProperties, ycbcr_props); | ||||||
|    if (result != VK_SUCCESS) |    if (result != VK_SUCCESS) | ||||||
|       goto fail; |       goto fail; | ||||||
| @@ -1079,6 +1304,9 @@ VkResult anv_GetPhysicalDeviceImageFormatProperties2( | |||||||
|     *    If handleType is 0, vkGetPhysicalDeviceImageFormatProperties2 will |     *    If handleType is 0, vkGetPhysicalDeviceImageFormatProperties2 will | ||||||
|     *    behave as if VkPhysicalDeviceExternalImageFormatInfo was not |     *    behave as if VkPhysicalDeviceExternalImageFormatInfo was not | ||||||
|     *    present and VkExternalImageFormatProperties will be ignored. |     *    present and VkExternalImageFormatProperties will be ignored. | ||||||
|  |     * | ||||||
|  |     * FINISHME(VK_EXT_image_drm_format_modifier): Consider impact of | ||||||
|  |     * VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT on external handles. | ||||||
|     */ |     */ | ||||||
|    if (external_info && external_info->handleType != 0) { |    if (external_info && external_info->handleType != 0) { | ||||||
|       switch (external_info->handleType) { |       switch (external_info->handleType) { | ||||||
|   | |||||||
| @@ -27,7 +27,6 @@ | |||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| #include <fcntl.h> | #include <fcntl.h> | ||||||
| #include <sys/mman.h> | #include <sys/mman.h> | ||||||
| #include "drm-uapi/drm_fourcc.h" |  | ||||||
|  |  | ||||||
| #include "anv_private.h" | #include "anv_private.h" | ||||||
| #include "util/debug.h" | #include "util/debug.h" | ||||||
| @@ -93,11 +92,10 @@ choose_isl_surf_usage(VkImageCreateFlags vk_create_flags, | |||||||
| } | } | ||||||
|  |  | ||||||
| static isl_tiling_flags_t | static isl_tiling_flags_t | ||||||
| choose_isl_tiling_flags(const struct anv_image_create_info *anv_info, | choose_isl_tiling_flags(const struct VkImageCreateInfo *base_info, | ||||||
|                         const struct isl_drm_modifier_info *isl_mod_info, |                         const struct isl_drm_modifier_info *isl_mod_info, | ||||||
|                         bool legacy_scanout) |                         bool legacy_scanout) | ||||||
| { | { | ||||||
|    const VkImageCreateInfo *base_info = anv_info->vk_info; |  | ||||||
|    isl_tiling_flags_t flags = 0; |    isl_tiling_flags_t flags = 0; | ||||||
|  |  | ||||||
|    switch (base_info->tiling) { |    switch (base_info->tiling) { | ||||||
| @@ -111,9 +109,6 @@ choose_isl_tiling_flags(const struct anv_image_create_info *anv_info, | |||||||
|       break; |       break; | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    if (anv_info->isl_tiling_flags) |  | ||||||
|       flags &= anv_info->isl_tiling_flags; |  | ||||||
|  |  | ||||||
|    if (legacy_scanout) |    if (legacy_scanout) | ||||||
|       flags &= ISL_TILING_LINEAR_BIT | ISL_TILING_X_BIT; |       flags &= ISL_TILING_LINEAR_BIT | ISL_TILING_X_BIT; | ||||||
|  |  | ||||||
| @@ -331,7 +326,9 @@ make_surface(const struct anv_device *dev, | |||||||
|    isl_surf_usage_flags_t shadow_usage = 0; |    isl_surf_usage_flags_t shadow_usage = 0; | ||||||
|    if (dev->info.gen <= 8 && |    if (dev->info.gen <= 8 && | ||||||
|        (image->create_flags & VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT) && |        (image->create_flags & VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT) && | ||||||
|        image->tiling == VK_IMAGE_TILING_OPTIMAL) { |        image->tiling.vk == VK_IMAGE_TILING_OPTIMAL) { | ||||||
|  |       assert(image->tiling.drm_format_mod == DRM_FORMAT_MOD_INVALID || | ||||||
|  |              image->tiling.drm_format_mod == DRM_FORMAT_MOD_LINEAR); | ||||||
|       assert(isl_format_is_compressed(plane_format.isl_format)); |       assert(isl_format_is_compressed(plane_format.isl_format)); | ||||||
|       tiling_flags = ISL_TILING_LINEAR_BIT; |       tiling_flags = ISL_TILING_LINEAR_BIT; | ||||||
|       needs_shadow = true; |       needs_shadow = true; | ||||||
| @@ -567,15 +564,47 @@ anv_image_create(VkDevice _device, | |||||||
|  |  | ||||||
|    assert(pCreateInfo->sType == VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO); |    assert(pCreateInfo->sType == VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO); | ||||||
|  |  | ||||||
|  |    /* The pNext chain must not provide multiple methods of selecting | ||||||
|  |     * a modifier. | ||||||
|  |     */ | ||||||
|  |    int mod_selections = 0; | ||||||
|  |  | ||||||
|  |    const VkImageDrmFormatModifierListCreateInfoEXT *drm_list_info = | ||||||
|  |       vk_find_struct_const(pCreateInfo->pNext, IMAGE_DRM_FORMAT_MODIFIER_LIST_CREATE_INFO_EXT); | ||||||
|  |    if (drm_list_info) { | ||||||
|  |       ++mod_selections; | ||||||
|  |       isl_mod_info = choose_drm_format_mod(&device->instance->physicalDevice, | ||||||
|  |                                            drm_list_info->drmFormatModifierCount, | ||||||
|  |                                            drm_list_info->pDrmFormatModifiers); | ||||||
|  |    } | ||||||
|  |  | ||||||
|    const struct wsi_image_create_info *wsi_info = |    const struct wsi_image_create_info *wsi_info = | ||||||
|       vk_find_struct_const(pCreateInfo->pNext, WSI_IMAGE_CREATE_INFO_MESA); |       vk_find_struct_const(pCreateInfo->pNext, WSI_IMAGE_CREATE_INFO_MESA); | ||||||
|    if (wsi_info && wsi_info->modifier_count > 0) { |    if (wsi_info && wsi_info->modifier_count > 0) { | ||||||
|  |       ++mod_selections; | ||||||
|       isl_mod_info = choose_drm_format_mod(&device->instance->physicalDevice, |       isl_mod_info = choose_drm_format_mod(&device->instance->physicalDevice, | ||||||
|                                            wsi_info->modifier_count, |                                            wsi_info->modifier_count, | ||||||
|                                            wsi_info->modifiers); |                                            wsi_info->modifiers); | ||||||
|       assert(isl_mod_info); |  | ||||||
|    } |    } | ||||||
|  |  | ||||||
|  |    const VkImageDrmFormatModifierExplicitCreateInfoEXT *drm_explicit_info = | ||||||
|  |       vk_find_struct_const(pCreateInfo->pNext, IMAGE_DRM_FORMAT_MODIFIER_EXPLICIT_CREATE_INFO_EXT); | ||||||
|  |    if (drm_explicit_info) { | ||||||
|  |       /* FINISHME(VK_EXT_image_drm_format_modifier) */ | ||||||
|  |       anv_finishme("VkImageDrmFormatModifierExplicitCreateInfoEXT"); | ||||||
|  |       abort(); | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    if (create_info->drm_format_mod != DRM_FORMAT_MOD_INVALID) { | ||||||
|  |       ++mod_selections; | ||||||
|  |       isl_mod_info = isl_drm_modifier_get_info(create_info->drm_format_mod); | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    assert(mod_selections <= 1); | ||||||
|  |  | ||||||
|  |    if (mod_selections > 0) | ||||||
|  |       assert(isl_mod_info); | ||||||
|  |  | ||||||
|    anv_assert(pCreateInfo->mipLevels > 0); |    anv_assert(pCreateInfo->mipLevels > 0); | ||||||
|    anv_assert(pCreateInfo->arrayLayers > 0); |    anv_assert(pCreateInfo->arrayLayers > 0); | ||||||
|    anv_assert(pCreateInfo->samples > 0); |    anv_assert(pCreateInfo->samples > 0); | ||||||
| @@ -598,11 +627,11 @@ anv_image_create(VkDevice _device, | |||||||
|    image->samples = pCreateInfo->samples; |    image->samples = pCreateInfo->samples; | ||||||
|    image->usage = pCreateInfo->usage; |    image->usage = pCreateInfo->usage; | ||||||
|    image->create_flags = pCreateInfo->flags; |    image->create_flags = pCreateInfo->flags; | ||||||
|    image->tiling = pCreateInfo->tiling; |  | ||||||
|    image->disjoint = pCreateInfo->flags & VK_IMAGE_CREATE_DISJOINT_BIT; |    image->disjoint = pCreateInfo->flags & VK_IMAGE_CREATE_DISJOINT_BIT; | ||||||
|    image->needs_set_tiling = wsi_info && wsi_info->scanout; |    image->needs_set_tiling = wsi_info && wsi_info->scanout; | ||||||
|    image->drm_format_mod = isl_mod_info ? isl_mod_info->modifier : |    image->tiling.vk = pCreateInfo->tiling; | ||||||
|                                           DRM_FORMAT_MOD_INVALID; |    image->tiling.drm_format_mod = | ||||||
|  |       isl_mod_info ? isl_mod_info->modifier : DRM_FORMAT_MOD_INVALID; | ||||||
|  |  | ||||||
|    if (image->aspects & VK_IMAGE_ASPECT_STENCIL_BIT) { |    if (image->aspects & VK_IMAGE_ASPECT_STENCIL_BIT) { | ||||||
|       image->stencil_usage = pCreateInfo->usage; |       image->stencil_usage = pCreateInfo->usage; | ||||||
| @@ -626,7 +655,7 @@ anv_image_create(VkDevice _device, | |||||||
|    assert(format != NULL); |    assert(format != NULL); | ||||||
|  |  | ||||||
|    const isl_tiling_flags_t isl_tiling_flags = |    const isl_tiling_flags_t isl_tiling_flags = | ||||||
|       choose_isl_tiling_flags(create_info, isl_mod_info, |       choose_isl_tiling_flags(pCreateInfo, isl_mod_info, | ||||||
|                               image->needs_set_tiling); |                               image->needs_set_tiling); | ||||||
|  |  | ||||||
|    image->n_planes = format->n_planes; |    image->n_planes = format->n_planes; | ||||||
| @@ -707,9 +736,9 @@ anv_image_from_swapchain(VkDevice device, | |||||||
|    struct wsi_image_create_info local_wsi_info = { |    struct wsi_image_create_info local_wsi_info = { | ||||||
|       .sType = VK_STRUCTURE_TYPE_WSI_IMAGE_CREATE_INFO_MESA, |       .sType = VK_STRUCTURE_TYPE_WSI_IMAGE_CREATE_INFO_MESA, | ||||||
|       .modifier_count = 1, |       .modifier_count = 1, | ||||||
|       .modifiers = &swapchain_image->drm_format_mod, |       .modifiers = &swapchain_image->tiling.drm_format_mod, | ||||||
|    }; |    }; | ||||||
|    if (swapchain_image->drm_format_mod != DRM_FORMAT_MOD_INVALID) |    if (swapchain_image->tiling.drm_format_mod != DRM_FORMAT_MOD_INVALID) | ||||||
|       __vk_append_struct(&local_create_info, &local_wsi_info); |       __vk_append_struct(&local_create_info, &local_wsi_info); | ||||||
|  |  | ||||||
|    return anv_image_create(device, |    return anv_image_create(device, | ||||||
| @@ -810,20 +839,20 @@ resolve_ahw_image(struct anv_device *device, | |||||||
|  |  | ||||||
|    /* Check tiling. */ |    /* Check tiling. */ | ||||||
|    int i915_tiling = anv_gem_get_tiling(device, mem->bo->gem_handle); |    int i915_tiling = anv_gem_get_tiling(device, mem->bo->gem_handle); | ||||||
|    VkImageTiling vk_tiling; |    struct anv_tiling tiling; | ||||||
|    isl_tiling_flags_t isl_tiling_flags = 0; |    isl_tiling_flags_t isl_tiling_flags = 0; | ||||||
|  |  | ||||||
|    switch (i915_tiling) { |    switch (i915_tiling) { | ||||||
|    case I915_TILING_NONE: |    case I915_TILING_NONE: | ||||||
|       vk_tiling = VK_IMAGE_TILING_LINEAR; |       tiling = anv_tiling_linear(); | ||||||
|       isl_tiling_flags = ISL_TILING_LINEAR_BIT; |       isl_tiling_flags = ISL_TILING_LINEAR_BIT; | ||||||
|       break; |       break; | ||||||
|    case I915_TILING_X: |    case I915_TILING_X: | ||||||
|       vk_tiling = VK_IMAGE_TILING_OPTIMAL; |       tiling = anv_tiling_optimal(); | ||||||
|       isl_tiling_flags = ISL_TILING_X_BIT; |       isl_tiling_flags = ISL_TILING_X_BIT; | ||||||
|       break; |       break; | ||||||
|    case I915_TILING_Y: |    case I915_TILING_Y: | ||||||
|       vk_tiling = VK_IMAGE_TILING_OPTIMAL; |       tiling = anv_tiling_optimal(); | ||||||
|       isl_tiling_flags = ISL_TILING_Y0_BIT; |       isl_tiling_flags = ISL_TILING_Y0_BIT; | ||||||
|       break; |       break; | ||||||
|    case -1: |    case -1: | ||||||
| @@ -831,15 +860,15 @@ resolve_ahw_image(struct anv_device *device, | |||||||
|       unreachable("Invalid tiling flags."); |       unreachable("Invalid tiling flags."); | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    assert(vk_tiling == VK_IMAGE_TILING_LINEAR || |    assert(tiling.vk == VK_IMAGE_TILING_LINEAR || | ||||||
|           vk_tiling == VK_IMAGE_TILING_OPTIMAL); |           tiling.vk == VK_IMAGE_TILING_OPTIMAL); | ||||||
|  |  | ||||||
|    /* Check format. */ |    /* Check format. */ | ||||||
|    VkFormat vk_format = vk_format_from_android(desc.format, desc.usage); |    VkFormat vk_format = vk_format_from_android(desc.format, desc.usage); | ||||||
|    enum isl_format isl_fmt = anv_get_isl_format(&device->info, |    enum isl_format isl_fmt = anv_get_isl_format(&device->info, | ||||||
|                                                 vk_format, |                                                 vk_format, | ||||||
|                                                 VK_IMAGE_ASPECT_COLOR_BIT, |                                                 VK_IMAGE_ASPECT_COLOR_BIT, | ||||||
|                                                 vk_tiling); |                                                 tiling); | ||||||
|    assert(isl_fmt != ISL_FORMAT_UNSUPPORTED); |    assert(isl_fmt != ISL_FORMAT_UNSUPPORTED); | ||||||
|  |  | ||||||
|    /* Handle RGB(X)->RGBA fallback. */ |    /* Handle RGB(X)->RGBA fallback. */ | ||||||
| @@ -976,10 +1005,17 @@ void anv_GetImageSubresourceLayout( | |||||||
| { | { | ||||||
|    ANV_FROM_HANDLE(anv_image, image, _image); |    ANV_FROM_HANDLE(anv_image, image, _image); | ||||||
|  |  | ||||||
|  |    if (image->tiling.vk == VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT) { | ||||||
|  |       /* FINSIHME(VK_EXT_image_drm_format_modifier) */ | ||||||
|  |       anv_finishme("vkGetImageSubresourceLayout for " | ||||||
|  |                    "VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT"); | ||||||
|  |       abort(); | ||||||
|  |    } | ||||||
|  |  | ||||||
|    const struct anv_surface *surface; |    const struct anv_surface *surface; | ||||||
|    if (subresource->aspectMask == VK_IMAGE_ASPECT_PLANE_1_BIT && |    if (subresource->aspectMask == VK_IMAGE_ASPECT_PLANE_1_BIT && | ||||||
|        image->drm_format_mod != DRM_FORMAT_MOD_INVALID && |        image->tiling.drm_format_mod != DRM_FORMAT_MOD_INVALID && | ||||||
|        isl_drm_modifier_has_aux(image->drm_format_mod)) |        isl_drm_modifier_has_aux(image->tiling.drm_format_mod)) | ||||||
|       surface = &image->planes[0].aux_surface; |       surface = &image->planes[0].aux_surface; | ||||||
|    else |    else | ||||||
|       surface = get_surface(image, subresource->aspectMask); |       surface = get_surface(image, subresource->aspectMask); | ||||||
| @@ -1008,6 +1044,16 @@ void anv_GetImageSubresourceLayout( | |||||||
|    } |    } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void anv_GetImageDrmFormatModifierPropertiesEXT( | ||||||
|  |     VkDevice                                    _device, | ||||||
|  |     VkImage                                     _image, | ||||||
|  |     VkImageDrmFormatModifierListCreateInfoEXT*   pProperties) | ||||||
|  | { | ||||||
|  |       /* FINISHME(VK_EXT_image_drm_format_modifier) */ | ||||||
|  |       anv_finishme("vkGetImageDrmFormatModifierPropertiesEXT"); | ||||||
|  |       abort(); | ||||||
|  | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * This function determines the optimal buffer to use for a given |  * This function determines the optimal buffer to use for a given | ||||||
|  * VkImageLayout and other pieces of information needed to make that |  * VkImageLayout and other pieces of information needed to make that | ||||||
| @@ -1049,7 +1095,7 @@ anv_layout_to_aux_usage(const struct gen_device_info * const devinfo, | |||||||
|       return ISL_AUX_USAGE_NONE; |       return ISL_AUX_USAGE_NONE; | ||||||
|  |  | ||||||
|    /* All images that use an auxiliary surface are required to be tiled. */ |    /* All images that use an auxiliary surface are required to be tiled. */ | ||||||
|    assert(image->tiling == VK_IMAGE_TILING_OPTIMAL); |    assert(!anv_tiling_is_linear(image->tiling)); | ||||||
|  |  | ||||||
|    /* Stencil has no aux */ |    /* Stencil has no aux */ | ||||||
|    assert(aspect != VK_IMAGE_ASPECT_STENCIL_BIT); |    assert(aspect != VK_IMAGE_ASPECT_STENCIL_BIT); | ||||||
| @@ -1117,7 +1163,7 @@ anv_layout_to_aux_usage(const struct gen_device_info * const devinfo, | |||||||
|        * the modifier. |        * the modifier. | ||||||
|        */ |        */ | ||||||
|       const struct isl_drm_modifier_info *mod_info = |       const struct isl_drm_modifier_info *mod_info = | ||||||
|          isl_drm_modifier_get_info(image->drm_format_mod); |          isl_drm_modifier_get_info(image->tiling.drm_format_mod); | ||||||
|       return mod_info ? mod_info->aux_usage : ISL_AUX_USAGE_NONE; |       return mod_info ? mod_info->aux_usage : ISL_AUX_USAGE_NONE; | ||||||
|    } |    } | ||||||
|  |  | ||||||
| @@ -1179,7 +1225,7 @@ anv_layout_to_fast_clear_type(const struct gen_device_info * const devinfo, | |||||||
|       return ANV_FAST_CLEAR_NONE; |       return ANV_FAST_CLEAR_NONE; | ||||||
|  |  | ||||||
|    /* All images that use an auxiliary surface are required to be tiled. */ |    /* All images that use an auxiliary surface are required to be tiled. */ | ||||||
|    assert(image->tiling == VK_IMAGE_TILING_OPTIMAL); |    assert(!anv_tiling_is_linear(image->tiling)); | ||||||
|  |  | ||||||
|    /* Stencil has no aux */ |    /* Stencil has no aux */ | ||||||
|    assert(aspect != VK_IMAGE_ASPECT_STENCIL_BIT); |    assert(aspect != VK_IMAGE_ASPECT_STENCIL_BIT); | ||||||
| @@ -1214,7 +1260,7 @@ anv_layout_to_fast_clear_type(const struct gen_device_info * const devinfo, | |||||||
|        * just always return NONE.  One day, this will change. |        * just always return NONE.  One day, this will change. | ||||||
|        */ |        */ | ||||||
|       const struct isl_drm_modifier_info *mod_info = |       const struct isl_drm_modifier_info *mod_info = | ||||||
|          isl_drm_modifier_get_info(image->drm_format_mod); |          isl_drm_modifier_get_info(image->tiling.drm_format_mod); | ||||||
|       assert(!mod_info || !mod_info->supports_clear_color); |       assert(!mod_info || !mod_info->supports_clear_color); | ||||||
| #endif | #endif | ||||||
|       return ANV_FAST_CLEAR_NONE; |       return ANV_FAST_CLEAR_NONE; | ||||||
| @@ -1765,7 +1811,7 @@ anv_CreateBufferView(VkDevice _device, | |||||||
|  |  | ||||||
|    view->format = anv_get_isl_format(&device->info, pCreateInfo->format, |    view->format = anv_get_isl_format(&device->info, pCreateInfo->format, | ||||||
|                                      VK_IMAGE_ASPECT_COLOR_BIT, |                                      VK_IMAGE_ASPECT_COLOR_BIT, | ||||||
|                                      VK_IMAGE_TILING_LINEAR); |                                      anv_tiling_linear()); | ||||||
|    const uint32_t format_bs = isl_format_get_layout(view->format)->bpb / 8; |    const uint32_t format_bs = isl_format_get_layout(view->format)->bpb / 8; | ||||||
|    view->range = anv_buffer_get_range(buffer, pCreateInfo->offset, |    view->range = anv_buffer_get_range(buffer, pCreateInfo->offset, | ||||||
|                                               pCreateInfo->range); |                                               pCreateInfo->range); | ||||||
|   | |||||||
| @@ -51,7 +51,7 @@ VkResult anv_CreateDmaBufImageINTEL( | |||||||
|  |  | ||||||
|    result = anv_image_create(_device, |    result = anv_image_create(_device, | ||||||
|       &(struct anv_image_create_info) { |       &(struct anv_image_create_info) { | ||||||
|          .isl_tiling_flags = ISL_TILING_X_BIT, |          .drm_format_mod = I915_FORMAT_MOD_X_TILED, | ||||||
|          .stride = pCreateInfo->strideInBytes, |          .stride = pCreateInfo->strideInBytes, | ||||||
|          .vk_info = &(VkImageCreateInfo) { |          .vk_info = &(VkImageCreateInfo) { | ||||||
|             .sType = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO, |             .sType = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO, | ||||||
| @@ -61,7 +61,6 @@ VkResult anv_CreateDmaBufImageINTEL( | |||||||
|             .mipLevels = 1, |             .mipLevels = 1, | ||||||
|             .arrayLayers = 1, |             .arrayLayers = 1, | ||||||
|             .samples = 1, |             .samples = 1, | ||||||
|             /* FIXME: Need a way to use X tiling to allow scanout */ |  | ||||||
|             .tiling = VK_IMAGE_TILING_OPTIMAL, |             .tiling = VK_IMAGE_TILING_OPTIMAL, | ||||||
|             .usage = VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, |             .usage = VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, | ||||||
|             .flags = 0, |             .flags = 0, | ||||||
|   | |||||||
| @@ -43,6 +43,7 @@ | |||||||
| #define VG(x) | #define VG(x) | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #include "drm-uapi/drm_fourcc.h" | ||||||
| #include "common/gen_clflush.h" | #include "common/gen_clflush.h" | ||||||
| #include "common/gen_decoder.h" | #include "common/gen_decoder.h" | ||||||
| #include "common/gen_gem.h" | #include "common/gen_gem.h" | ||||||
| @@ -2912,6 +2913,54 @@ anv_plane_to_aspect(VkImageAspectFlags image_aspects, | |||||||
| #define anv_foreach_image_aspect_bit(b, image, aspects) \ | #define anv_foreach_image_aspect_bit(b, image, aspects) \ | ||||||
|    for_each_bit(b, anv_image_expand_aspects(image, aspects)) |    for_each_bit(b, anv_image_expand_aspects(image, aspects)) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** For valid values, see anv_tiling_validate(). */ | ||||||
|  | struct anv_tiling { | ||||||
|  |    VkImageTiling vk; | ||||||
|  |    uint64_t drm_format_mod; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | /** Return the equivalent of VK_IMAGE_TILING_LINEAR. */ | ||||||
|  | static inline struct anv_tiling | ||||||
|  | anv_tiling_linear(void) | ||||||
|  | { | ||||||
|  |    return (struct anv_tiling) { | ||||||
|  |       .vk = VK_IMAGE_TILING_LINEAR, | ||||||
|  |       .drm_format_mod = DRM_FORMAT_MOD_INVALID, | ||||||
|  |    }; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** Return the equivalent of VK_IMAGE_TILING_OPTIMAL. */ | ||||||
|  | static inline struct anv_tiling | ||||||
|  | anv_tiling_optimal(void) | ||||||
|  | { | ||||||
|  |    return (struct anv_tiling) { | ||||||
|  |       .vk = VK_IMAGE_TILING_OPTIMAL, | ||||||
|  |       .drm_format_mod = DRM_FORMAT_MOD_INVALID, | ||||||
|  |    }; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** Return tiling with VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT. */ | ||||||
|  | static inline struct anv_tiling | ||||||
|  | anv_tiling_drm(uint64_t drm_format_mod) | ||||||
|  | { | ||||||
|  |    return (struct anv_tiling) { | ||||||
|  |       .vk = VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT, | ||||||
|  |       .drm_format_mod = drm_format_mod, | ||||||
|  |    }; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Check whether the physical tiling, not the api-visible nominal tiling, is | ||||||
|  |  * linear. | ||||||
|  |  */ | ||||||
|  | static inline bool | ||||||
|  | anv_tiling_is_linear(struct anv_tiling tiling) | ||||||
|  | { | ||||||
|  |    return tiling.vk == VK_IMAGE_TILING_LINEAR || | ||||||
|  |           tiling.drm_format_mod == DRM_FORMAT_MOD_LINEAR; | ||||||
|  | } | ||||||
|  |  | ||||||
| const struct anv_format * | const struct anv_format * | ||||||
| anv_get_format(VkFormat format); | anv_get_format(VkFormat format); | ||||||
|  |  | ||||||
| @@ -2925,11 +2974,11 @@ anv_get_format_planes(VkFormat vk_format) | |||||||
|  |  | ||||||
| struct anv_format_plane | struct anv_format_plane | ||||||
| anv_get_format_plane(const struct gen_device_info *devinfo, VkFormat vk_format, | anv_get_format_plane(const struct gen_device_info *devinfo, VkFormat vk_format, | ||||||
|                      VkImageAspectFlagBits aspect, VkImageTiling tiling); |                      VkImageAspectFlagBits aspect, struct anv_tiling tiling); | ||||||
|  |  | ||||||
| static inline enum isl_format | static inline enum isl_format | ||||||
| anv_get_isl_format(const struct gen_device_info *devinfo, VkFormat vk_format, | anv_get_isl_format(const struct gen_device_info *devinfo, VkFormat vk_format, | ||||||
|                    VkImageAspectFlags aspect, VkImageTiling tiling) |                    VkImageAspectFlags aspect, struct anv_tiling tiling) | ||||||
| { | { | ||||||
|    return anv_get_format_plane(devinfo, vk_format, aspect, tiling).isl_format; |    return anv_get_format_plane(devinfo, vk_format, aspect, tiling).isl_format; | ||||||
| } | } | ||||||
| @@ -2982,7 +3031,7 @@ struct anv_image { | |||||||
|    VkImageUsageFlags usage; /**< VkImageCreateInfo::usage. */ |    VkImageUsageFlags usage; /**< VkImageCreateInfo::usage. */ | ||||||
|    VkImageUsageFlags stencil_usage; |    VkImageUsageFlags stencil_usage; | ||||||
|    VkImageCreateFlags create_flags; /* Flags used when creating image. */ |    VkImageCreateFlags create_flags; /* Flags used when creating image. */ | ||||||
|    VkImageTiling tiling; /** VkImageCreateInfo::tiling */ |    struct anv_tiling tiling; | ||||||
|  |  | ||||||
|    /** True if this is needs to be bound to an appropriately tiled BO. |    /** True if this is needs to be bound to an appropriately tiled BO. | ||||||
|     * |     * | ||||||
| @@ -2993,12 +3042,6 @@ struct anv_image { | |||||||
|     */ |     */ | ||||||
|    bool needs_set_tiling; |    bool needs_set_tiling; | ||||||
|  |  | ||||||
|    /** |  | ||||||
|     * Must be DRM_FORMAT_MOD_INVALID unless tiling is |  | ||||||
|     * VK_IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT. |  | ||||||
|     */ |  | ||||||
|    uint64_t drm_format_mod; |  | ||||||
|  |  | ||||||
|    VkDeviceSize size; |    VkDeviceSize size; | ||||||
|    uint32_t alignment; |    uint32_t alignment; | ||||||
|  |  | ||||||
| @@ -3405,8 +3448,8 @@ void anv_image_fill_surface_state(struct anv_device *device, | |||||||
| struct anv_image_create_info { | struct anv_image_create_info { | ||||||
|    const VkImageCreateInfo *vk_info; |    const VkImageCreateInfo *vk_info; | ||||||
|  |  | ||||||
|    /** An opt-in bitmask which filters an ISL-mapping of the Vulkan tiling. */ |    /** Force a specific tiling unless DRM_FORMAT_MOD_INVALID. */ | ||||||
|    isl_tiling_flags_t isl_tiling_flags; |    uint64_t drm_format_mod; | ||||||
|  |  | ||||||
|    /** These flags will be added to any derived from VkImageCreateInfo. */ |    /** These flags will be added to any derived from VkImageCreateInfo. */ | ||||||
|    isl_surf_usage_flags_t isl_extra_usage_flags; |    isl_surf_usage_flags_t isl_extra_usage_flags; | ||||||
| @@ -3463,7 +3506,7 @@ VkFormatFeatureFlags | |||||||
| anv_get_image_format_features(const struct gen_device_info *devinfo, | anv_get_image_format_features(const struct gen_device_info *devinfo, | ||||||
|                               VkFormat vk_format, |                               VkFormat vk_format, | ||||||
|                               const struct anv_format *anv_format, |                               const struct anv_format *anv_format, | ||||||
|                               VkImageTiling vk_tiling); |                               struct anv_tiling tiling); | ||||||
|  |  | ||||||
| void anv_fill_buffer_surface_state(struct anv_device *device, | void anv_fill_buffer_surface_state(struct anv_device *device, | ||||||
|                                    struct anv_state state, |                                    struct anv_state state, | ||||||
|   | |||||||
| @@ -37,7 +37,7 @@ static uint64_t | |||||||
| anv_wsi_image_get_modifier(VkImage _image) | anv_wsi_image_get_modifier(VkImage _image) | ||||||
| { | { | ||||||
|    ANV_FROM_HANDLE(anv_image, image, _image); |    ANV_FROM_HANDLE(anv_image, image, _image); | ||||||
|    return image->drm_format_mod; |    return image->tiling.drm_format_mod; | ||||||
| } | } | ||||||
|  |  | ||||||
| VkResult | VkResult | ||||||
|   | |||||||
| @@ -1003,7 +1003,7 @@ transition_color_buffer(struct anv_cmd_buffer *cmd_buffer, | |||||||
|    if (base_layer >= anv_image_aux_layers(image, aspect, base_level)) |    if (base_layer >= anv_image_aux_layers(image, aspect, base_level)) | ||||||
|       return; |       return; | ||||||
|  |  | ||||||
|    assert(image->tiling == VK_IMAGE_TILING_OPTIMAL); |    assert(image->tiling.vk == VK_IMAGE_TILING_OPTIMAL); | ||||||
|  |  | ||||||
|    if (initial_layout == VK_IMAGE_LAYOUT_UNDEFINED || |    if (initial_layout == VK_IMAGE_LAYOUT_UNDEFINED || | ||||||
|        initial_layout == VK_IMAGE_LAYOUT_PREINITIALIZED) { |        initial_layout == VK_IMAGE_LAYOUT_PREINITIALIZED) { | ||||||
|   | |||||||
| @@ -150,7 +150,7 @@ emit_vertex_input(struct anv_pipeline *pipeline, | |||||||
|       enum isl_format format = anv_get_isl_format(&pipeline->device->info, |       enum isl_format format = anv_get_isl_format(&pipeline->device->info, | ||||||
|                                                   desc->format, |                                                   desc->format, | ||||||
|                                                   VK_IMAGE_ASPECT_COLOR_BIT, |                                                   VK_IMAGE_ASPECT_COLOR_BIT, | ||||||
|                                                   VK_IMAGE_TILING_LINEAR); |                                                   anv_tiling_linear()); | ||||||
|  |  | ||||||
|       assert(desc->binding < MAX_VBS); |       assert(desc->binding < MAX_VBS); | ||||||
|  |  | ||||||
| @@ -604,7 +604,7 @@ emit_rs_state(struct anv_pipeline *pipeline, | |||||||
|          enum isl_format isl_format = |          enum isl_format isl_format = | ||||||
|             anv_get_isl_format(&pipeline->device->info, vk_format, |             anv_get_isl_format(&pipeline->device->info, vk_format, | ||||||
|                                VK_IMAGE_ASPECT_DEPTH_BIT, |                                VK_IMAGE_ASPECT_DEPTH_BIT, | ||||||
|                                VK_IMAGE_TILING_OPTIMAL); |                                anv_tiling_optimal()); | ||||||
|          sf.DepthBufferSurfaceFormat = |          sf.DepthBufferSurfaceFormat = | ||||||
|             isl_format_get_depth_format(isl_format, false); |             isl_format_get_depth_format(isl_format, false); | ||||||
|       } |       } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user