[Mesa-dev] [PATCH 04/15] i965: Prepare up/downsampling for isl based miptrees

Nanley Chery nanleychery at gmail.com
Wed Jun 14 23:08:25 UTC 2017


On Tue, Jun 13, 2017 at 05:50:02PM +0300, Topi Pohjolainen wrote:
> Signed-off-by: Topi Pohjolainen <topi.pohjolainen at intel.com>
> ---
>  src/mesa/drivers/dri/i965/intel_mipmap_tree.c | 46 ++++++++++++++++++++++-----
>  1 file changed, 38 insertions(+), 8 deletions(-)
> 
Patches 2-4 are
Reviewed-by: Nanley Chery <nanley.g.chery at intel.com>

> diff --git a/src/mesa/drivers/dri/i965/intel_mipmap_tree.c b/src/mesa/drivers/dri/i965/intel_mipmap_tree.c
> index 78a223a7f3..061860cdf6 100644
> --- a/src/mesa/drivers/dri/i965/intel_mipmap_tree.c
> +++ b/src/mesa/drivers/dri/i965/intel_mipmap_tree.c
> @@ -2800,27 +2800,57 @@ intel_miptree_updownsample(struct brw_context *brw,
>                             struct intel_mipmap_tree *src,
>                             struct intel_mipmap_tree *dst)
>  {
> +   unsigned src_w, src_h, dst_w, dst_h;
> +
> +   if (src->surf.size > 0) {
> +      src_w = src->surf.logical_level0_px.width;
> +      src_h = src->surf.logical_level0_px.height;
> +   } else {
> +      src_w = src->logical_width0;
> +      src_h = src->logical_height0;
> +   }
> +
> +   if (dst->surf.size > 0) {
> +      dst_w = dst->surf.logical_level0_px.width;
> +      dst_h = dst->surf.logical_level0_px.height;
> +   } else {
> +      dst_w = dst->logical_width0;
> +      dst_h = dst->logical_height0;
> +   }
> +
>     brw_blorp_blit_miptrees(brw,
>                             src, 0 /* level */, 0 /* layer */,
>                             src->format, SWIZZLE_XYZW,
>                             dst, 0 /* level */, 0 /* layer */, dst->format,
> -                           0, 0,
> -                           src->logical_width0, src->logical_height0,
> -                           0, 0,
> -                           dst->logical_width0, dst->logical_height0,
> +                           0, 0, src_w, src_h,
> +                           0, 0, dst_w, dst_h,
>                             GL_NEAREST, false, false /*mirror x, y*/,
>                             false, false);
>  
>     if (src->stencil_mt) {
> +      if (src->stencil_mt->surf.size > 0) {
> +         src_w = src->stencil_mt->surf.logical_level0_px.width;
> +         src_h = src->stencil_mt->surf.logical_level0_px.height;
> +      } else {
> +         src_w = src->stencil_mt->logical_width0;
> +         src_h = src->stencil_mt->logical_height0;
> +      }
> +
> +      if (dst->stencil_mt->surf.size > 0) {
> +         dst_w = dst->stencil_mt->surf.logical_level0_px.width;
> +         dst_h = dst->stencil_mt->surf.logical_level0_px.height;
> +      } else {
> +         dst_w = dst->stencil_mt->logical_width0;
> +         dst_h = dst->stencil_mt->logical_height0;
> +      }
> +
>        brw_blorp_blit_miptrees(brw,
>                                src->stencil_mt, 0 /* level */, 0 /* layer */,
>                                src->stencil_mt->format, SWIZZLE_XYZW,
>                                dst->stencil_mt, 0 /* level */, 0 /* layer */,
>                                dst->stencil_mt->format,
> -                              0, 0,
> -                              src->logical_width0, src->logical_height0,
> -                              0, 0,
> -                              dst->logical_width0, dst->logical_height0,
> +                              0, 0, src_w, src_h,
> +                              0, 0, dst_w, dst_h,
>                                GL_NEAREST, false, false /*mirror x, y*/,
>                                false, false /* decode/encode srgb */);
>     }
> -- 
> 2.11.0
> 
> _______________________________________________
> 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