pan/bi: Cull DTSEL_IMM dests in post-RA DCE
authorAlyssa Rosenzweig <alyssa@collabora.com>
Thu, 23 Dec 2021 18:12:19 +0000 (13:12 -0500)
committerMarge Bot <emma+marge@anholt.net>
Tue, 22 Feb 2022 16:57:30 +0000 (16:57 +0000)
They are useless (given the semantics of DTSEL_IMM) and complicate
scoreboarding. Just remove them in the pass that removes all the other silly
register destinations.

Signed-off-by: Alyssa Rosenzweig <alyssa@collabora.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/14298>

src/panfrost/bifrost/bi_opt_dce.c

index 141591d..d1d3592 100644 (file)
@@ -160,6 +160,9 @@ bi_opt_dce_post_ra(bi_context *ctx)
                 uint64_t live = block->reg_live_out;
 
                 bi_foreach_instr_in_block_rev(block, ins) {
+                        if (ins->op == BI_OPCODE_DTSEL_IMM)
+                                ins->dest[0] = bi_null();
+
                         bi_foreach_dest(ins, d) {
                                 if (ins->dest[d].type != BI_INDEX_REGISTER)
                                         continue;