[Mesa-dev] [PATCH] anv/meta: Use ISL to get the image tile height

Nanley Chery nanleychery at gmail.com
Tue Mar 8 21:04:55 UTC 2016


On Tue, Mar 08, 2016 at 10:41:24AM -0800, Anuj Phogat wrote:
> On Fri, Mar 4, 2016 at 2:03 PM, Nanley Chery <nanleychery at gmail.com> wrote:
> > From: Nanley Chery <nanley.g.chery at intel.com>
> >
> > In addition to making the height addition more understandable, this
> > future-proofs the code for new tiling modes and keeps the image
> > height as small as possible.
> >
> > Signed-off-by: Nanley Chery <nanley.g.chery at intel.com>
> > ---
> >  src/intel/vulkan/anv_meta_blit.c | 13 +++++++++++--
> >  1 file changed, 11 insertions(+), 2 deletions(-)
> >
> > diff --git a/src/intel/vulkan/anv_meta_blit.c b/src/intel/vulkan/anv_meta_blit.c
> > index b8a42f9..8b5873e 100644
> > --- a/src/intel/vulkan/anv_meta_blit.c
> > +++ b/src/intel/vulkan/anv_meta_blit.c
> > @@ -443,6 +443,12 @@ anv_meta_blit2d(struct anv_cmd_buffer *cmd_buffer,
> >
> >     for (unsigned r = 0; r < num_rects; ++r) {
> >
> > +      /* Used to store the height of a tile in the src/dst surface.
> > +       * The tile height is added to the image height to compensate
> > +       * for the rect's src/dst y-offsets.
> > +       */
> > +      struct isl_tile_info tile_info;
> > +
> >        /* Create VkImages */
> >        VkImageCreateInfo image_info = {
> >           .sType = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO,
> > @@ -450,8 +456,7 @@ anv_meta_blit2d(struct anv_cmd_buffer *cmd_buffer,
> >           .format = 0, /* TEMPLATE */
> >           .extent = {
> >              .width = 0, /* TEMPLATE */
> > -            /* Pad to highest tile height to compensate for a vertical intratile offset */
> > -            .height = MIN(rects[r].height + 64, 1 << 14),
> > +            .height = 0, /* TEMPLATE */
> >              .depth = 1,
> >           },
> >           .mipLevels = 1,
> > @@ -470,6 +475,8 @@ anv_meta_blit2d(struct anv_cmd_buffer *cmd_buffer,
> >                          VK_IMAGE_TILING_LINEAR : VK_IMAGE_TILING_OPTIMAL;
> >        image_info.usage = VK_IMAGE_USAGE_SAMPLED_BIT;
> >        image_info.format = src_format,
> > +      isl_tiling_get_info(&cmd_buffer->device->isl_dev, src->tiling, src->bs, &tile_info);
> > +      image_info.extent.height = MIN(rects[r].height + tile_info.height, 1 << 14);
> >        image_info.extent.width = src->pitch / src->bs;
> >        VkImage src_image;
> >        anv_image_create(vk_device, &anv_image_info,
> > @@ -480,6 +487,8 @@ anv_meta_blit2d(struct anv_cmd_buffer *cmd_buffer,
> >                          VK_IMAGE_TILING_LINEAR : VK_IMAGE_TILING_OPTIMAL;
> >        image_info.usage = VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT;
> >        image_info.format = dst_format,
> > +      isl_tiling_get_info(&cmd_buffer->device->isl_dev, dst->tiling, dst->bs, &tile_info);
> > +      image_info.extent.height = MIN(rects[r].height + tile_info.height, 1 << 14);
> >        image_info.extent.width = dst->pitch / dst->bs;
> >        VkImage dst_image;
> >        anv_image_create(vk_device, &anv_image_info,
> > --
> > 2.7.2
> >
> > _______________________________________________
> > mesa-dev mailing list
> > mesa-dev at lists.freedesktop.org
> > https://lists.freedesktop.org/mailman/listinfo/mesa-dev
> 
> LGTM.
> Reviewed-by: Anuj Phogat <anuj.phogat at gmail.com>

I noticed an improvement and just sent out a v2 of this patch:
https://patchwork.freedesktop.org/patch/76226/

Thanks for the initial R-b.


More information about the mesa-dev mailing list