From: Alyssa Rosenzweig Date: Fri, 18 Oct 2019 02:18:36 +0000 (-0400) Subject: pan/midgard: Simplify mir_bytemask_of_read_components X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=43fd730fc4d9382b94cc6f296f4e07e7508c3ca3;p=mesa.git pan/midgard: Simplify mir_bytemask_of_read_components There are easy ways to iterate sources! Signed-off-by: Alyssa Rosenzweig --- diff --git a/src/panfrost/midgard/mir.c b/src/panfrost/midgard/mir.c index 09868302a2e..76c99a2e05c 100644 --- a/src/panfrost/midgard/mir.c +++ b/src/panfrost/midgard/mir.c @@ -548,29 +548,15 @@ mir_bytemask_of_read_components_single(unsigned swizzle, unsigned inmask, midgar return mir_to_bytemask(mode, cmask); } -static unsigned -mir_source_count(midgard_instruction *ins) -{ - if (ins->type == TAG_ALU_4) { - /* ALU is always binary, except csel */ - return OP_IS_CSEL(ins->alu.op) ? 3 : 2; - } else if (ins->type == TAG_LOAD_STORE_4) { - bool load = !OP_IS_STORE(ins->load_store.op); - return (load ? 2 : 3); - } else if (ins->type == TAG_TEXTURE_4) { - /* Coords, bias.. TODO: Offsets? */ - return 2; - } else { - unreachable("Invalid instruction type"); - } -} - uint16_t mir_bytemask_of_read_components(midgard_instruction *ins, unsigned node) { uint16_t mask = 0; - for (unsigned i = 0; i < mir_source_count(ins); ++i) { + if (node == ~0) + return 0; + + mir_foreach_src(ins, i) { if (ins->src[i] != node) continue; /* Branch writeout uses all components */