Pārlūkot izejas kodu

freedreno/ir3: don't cp absneg into meta:fi

If using a fanin (collect) to collect of consecutive registers together,
we can CP mov's into the fanin, but not (abs) or (neg).  No places that
allow those modifiers are consuming a fanin anyways.  But this caused an
absneg to be lost between a ldgb and stgb for shaders like:

  outputs[n] = abs(input[n])

Signed-off-by: Rob Clark <robdclark@gmail.com>
tags/18.2-branchpoint
Rob Clark pirms 7 gadiem
vecāks
revīzija
cf5dda3349
1 mainītis faili ar 4 papildinājumiem un 0 dzēšanām
  1. 4
    0
      src/gallium/drivers/freedreno/ir3/ir3_cp.c

+ 4
- 0
src/gallium/drivers/freedreno/ir3/ir3_cp.c Parādīt failu

@@ -543,6 +543,10 @@ instr_cp(struct ir3_cp_ctx *ctx, struct ir3_instruction *instr)
if (reg->flags & IR3_REG_ARRAY)
continue;

/* Don't CP absneg into meta instructions, that won't end well: */
if (is_meta(instr) && (src->opc != OPC_MOV))
continue;

reg_cp(ctx, instr, reg, n);
}


Notiek ielāde…
Atcelt
Saglabāt