[Mesa-dev] [PATCH] i965/vec4: Detect and delete useless MOVs.

Jason Ekstrand jason at jlekstrand.net
Mon Sep 21 14:16:34 PDT 2015


On Mon, Sep 21, 2015 at 2:04 PM, Matt Turner <mattst88 at gmail.com> wrote:
> With NIR:
>
> instructions in affected programs:     111508 -> 109193 (-2.08%)
> helped:                                507

*sigh*  Any idea who's emitting these MOV's?  If it's vec_to_movs, we
should probably fix it one of these days.  In any case,

> Without NIR:
>
> instructions in affected programs:     28763 -> 28474 (-1.00%)
> helped:                                186
> ---
>  src/mesa/drivers/dri/i965/brw_vec4.cpp | 21 +++++++++++++++++++++
>  1 file changed, 21 insertions(+)
>
> diff --git a/src/mesa/drivers/dri/i965/brw_vec4.cpp b/src/mesa/drivers/dri/i965/brw_vec4.cpp
> index ed49cd3..d09a8dd 100644
> --- a/src/mesa/drivers/dri/i965/brw_vec4.cpp
> +++ b/src/mesa/drivers/dri/i965/brw_vec4.cpp
> @@ -1021,6 +1021,27 @@ vec4_visitor::opt_register_coalesce()
>           inst->src[0].abs || inst->src[0].negate || inst->src[0].reladdr)
>          continue;
>

Could we add a quick comment here that we're detecting a no-op MOV?

With that,

Reviewed-by: Jason Ekstrand <jason.ekstrand at intel.com>

Thanks fir fixing this!

--Jason

> +      if (inst->dst.file == inst->src[0].file &&
> +          inst->dst.reg == inst->src[0].reg &&
> +          inst->dst.reg_offset == inst->src[0].reg_offset) {
> +         bool is_nop_mov = true;
> +
> +         for (unsigned c = 0; c < 4; c++) {
> +            if ((inst->dst.writemask & (1 << c)) == 0)
> +               continue;
> +
> +            if (BRW_GET_SWZ(inst->src[0].swizzle, c) != c) {
> +               is_nop_mov = false;
> +               break;
> +            }
> +         }
> +
> +         if (is_nop_mov) {
> +            inst->remove(block);
> +            continue;
> +         }
> +      }
> +
>        bool to_mrf = (inst->dst.file == MRF);
>
>        /* Can't coalesce this GRF if someone else was going to
> --
> 2.4.6
>
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/mesa-dev


More information about the mesa-dev mailing list