aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorRob Clark <[email protected]>2019-11-01 15:17:22 -0700
committerRob Clark <[email protected]>2019-11-12 13:57:52 -0800
commit4bb697d938d17bbdd5124db0102d97fb9ead2229 (patch)
treea8bd7b9e286e31324379669bf7d49cea96f7a52d /src
parentbdf6b7018cedf95b554e21953d5a1935d3067ce7 (diff)
freedreno/ir3: only tex instructions have wrmask
At the ir3 level, we would assume that we could use wrmask to mask off other components of an instruction returning a vecN when they are not used. Which would let RA use components not written for other live values. But this is only true for tex instructions. Signed-off-by: Rob Clark <[email protected]> Reviewed-by: Kristian H. Kristensen <[email protected]> Reviewed-by: Eric Anholt <[email protected]>
Diffstat (limited to 'src')
-rw-r--r--src/freedreno/ir3/ir3_depth.c9
1 files changed, 3 insertions, 6 deletions
diff --git a/src/freedreno/ir3/ir3_depth.c b/src/freedreno/ir3/ir3_depth.c
index bdd00693104..4bbd1e56d7c 100644
--- a/src/freedreno/ir3/ir3_depth.c
+++ b/src/freedreno/ir3/ir3_depth.c
@@ -177,13 +177,10 @@ remove_unused_by_block(struct ir3_block *block)
if (instr->flags & IR3_INSTR_UNUSED) {
if (instr->opc == OPC_META_SPLIT) {
struct ir3_instruction *src = ssa(instr->regs[1]);
- /* leave inputs alone.. we can't optimize out components of
- * an input, since the hw is still going to be writing all
- * of the components, and we could end up in a situation
- * where multiple inputs overlap.
+ /* tex (cat5) instructions have a writemask, so we can
+ * mask off unused components. Other instructions do not.
*/
- if ((src->opc != OPC_META_INPUT) &&
- (src->regs[0]->wrmask > 1)) {
+ if (is_tex(src) && (src->regs[0]->wrmask > 1)) {
src->regs[0]->wrmask &= ~(1 << instr->split.off);
/* prune no-longer needed right-neighbors. We could