diff options
author | Alyssa Rosenzweig <[email protected]> | 2019-04-28 04:38:01 +0000 |
---|---|---|
committer | Alyssa Rosenzweig <[email protected]> | 2019-04-28 21:34:32 +0000 |
commit | 53d6e11393744423b7cbf29459b81bde80ba1516 (patch) | |
tree | f661ec4034109304da95b44c9c4f36d8650d4d93 /src | |
parent | 68a1508dc9dfb283dce18921273bf218086eb2ce (diff) |
panfrost/midgard: Fix tex propogation
Unbreaks mpv.
Signed-off-by: Alyssa Rosenzweig <[email protected]>
Diffstat (limited to 'src')
-rw-r--r-- | src/gallium/drivers/panfrost/midgard/midgard_compile.c | 29 |
1 files changed, 22 insertions, 7 deletions
diff --git a/src/gallium/drivers/panfrost/midgard/midgard_compile.c b/src/gallium/drivers/panfrost/midgard/midgard_compile.c index ac4c7219ce9..9098727aa15 100644 --- a/src/gallium/drivers/panfrost/midgard/midgard_compile.c +++ b/src/gallium/drivers/panfrost/midgard/midgard_compile.c @@ -3199,23 +3199,38 @@ midgard_opt_copy_prop_tex(compiler_context *ctx, midgard_block *block) unsigned from = ins->ssa_args.src1; unsigned to = ins->ssa_args.dest; - /* Make sure it's a familiar type of special move. Basically we - * just handle the special dummy moves emitted by the texture - * pipeline. TODO: verify. TODO: why does this break varyings? - */ + /* Make sure it's simple enough for us to handle */ if (from >= SSA_FIXED_MINIMUM) continue; + if (from >= ctx->func->impl->ssa_alloc) continue; if (to < SSA_FIXED_REGISTER(REGISTER_TEXTURE_BASE)) continue; if (to > SSA_FIXED_REGISTER(REGISTER_TEXTURE_BASE + 1)) continue; + bool eliminated = false; + mir_foreach_instr_in_block_from_rev(block, v, mir_prev_op(ins)) { + /* The texture registers are not SSA so be careful. + * Conservatively, just stop if we hit a texture op + * (even if it may not write) to where we are */ + + if (v->type != TAG_ALU_4) + break; + if (v->ssa_args.dest == from) { - v->ssa_args.dest = to; - progress = true; + /* We don't want to track partial writes ... */ + if (v->alu.mask == 0xF) { + v->ssa_args.dest = to; + eliminated = true; + } + + break; } } - mir_remove_instruction(ins); + if (eliminated) + mir_remove_instruction(ins); + + progress |= eliminated; } return progress; |