[Mesa-dev] [PATCH 03/29] anv/blorp: Support ISL_AUX_USAGE_HIZ in surf_for_anv_image

Nanley Chery nanleychery at gmail.com
Wed Dec 6 00:11:41 UTC 2017


On Mon, Nov 27, 2017 at 07:05:53PM -0800, Jason Ekstrand wrote:
> If the function gets passed ANV_AUX_USAGE_DEFAULT, it still has the old
> behavior of setting ISL_AUX_USAGE_NONE for depth/stencil which is what
> we want for blits/copies.
> ---
>  src/intel/vulkan/anv_blorp.c | 22 ++++++----------------
>  1 file changed, 6 insertions(+), 16 deletions(-)
> 
> diff --git a/src/intel/vulkan/anv_blorp.c b/src/intel/vulkan/anv_blorp.c
> index 7c8a673..f10adf0 100644
> --- a/src/intel/vulkan/anv_blorp.c
> +++ b/src/intel/vulkan/anv_blorp.c
> @@ -193,12 +193,13 @@ get_blorp_surf_for_anv_image(const struct anv_device *device,
>  {
>     uint32_t plane = anv_image_aspect_to_plane(image->aspects, aspect);
>  
> -   if (aux_usage == ANV_AUX_USAGE_DEFAULT)
> +   if (aux_usage == ANV_AUX_USAGE_DEFAULT) {
>        aux_usage = image->planes[plane].aux_usage;
>  
> -   if (aspect == VK_IMAGE_ASPECT_STENCIL_BIT ||
> -       aux_usage == ISL_AUX_USAGE_HIZ)
> -      aux_usage = ISL_AUX_USAGE_NONE;
> +      if (aspect == VK_IMAGE_ASPECT_STENCIL_BIT ||
> +          aux_usage == ISL_AUX_USAGE_HIZ)

I think the predicate no longer needs a check on the aspect. If the
aspect is stencil the aux_usage will either be NONE or HIZ. If the
aux_usage HIZ it'll be caught by the aux_usage check. If it's NONE
there's no work to be done. Either way, this patch is
Reviewed-by: Nanley Chery <nanley.g.chery at intel.com>


> +         aux_usage = ISL_AUX_USAGE_NONE;
> +   }
>  
>     const struct anv_surface *surface = &image->planes[plane].surface;
>     *blorp_surf = (struct blorp_surf) {
> @@ -1593,18 +1594,7 @@ anv_gen8_hiz_op_resolve(struct anv_cmd_buffer *cmd_buffer,
>     struct blorp_surf surf;
>     get_blorp_surf_for_anv_image(cmd_buffer->device,
>                                  image, VK_IMAGE_ASPECT_DEPTH_BIT,
> -                                ISL_AUX_USAGE_NONE, &surf);
> -
> -   /* Manually add the aux HiZ surf */
> -   surf.aux_surf = &image->planes[0].aux_surface.isl,
> -   surf.aux_addr = (struct blorp_address) {
> -      .buffer = image->planes[0].bo,
> -      .offset = image->planes[0].bo_offset +
> -                image->planes[0].aux_surface.offset,
> -      .mocs = cmd_buffer->device->default_mocs,
> -   };
> -   surf.aux_usage = ISL_AUX_USAGE_HIZ;
> -

Thanks for getting rid of that!

> +                                ISL_AUX_USAGE_HIZ, &surf);
>     surf.clear_color.f32[0] = ANV_HZ_FC_VAL;
>  
>     blorp_hiz_op(&batch, &surf, 0, 0, 1, op);
> -- 
> 2.5.0.400.gff86faf
> 
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/mesa-dev


More information about the mesa-dev mailing list