From: Tobias Klausmann Date: Fri, 30 Sep 2016 21:50:15 +0000 (+0200) Subject: nv50/ir: constant fold OP_SPLIT X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=b7d9677de804375827b3c433027ec2dd32cd1da6;p=mesa.git nv50/ir: constant fold OP_SPLIT Split the source immediate value into new values and move them into the original defs set by the split. Since we can only have up to 64-bit immediates, this is largely beneficial for F64 (and, in the future, U64) operations. Signed-off-by: Tobias Klausmann [imirkin: always use U32, set newi for foldCount tracking] Signed-off-by: Ilia Mirkin --- diff --git a/src/gallium/drivers/nouveau/codegen/nv50_ir_peephole.cpp b/src/gallium/drivers/nouveau/codegen/nv50_ir_peephole.cpp index 737bda3ee33..0fb1a7803bd 100644 --- a/src/gallium/drivers/nouveau/codegen/nv50_ir_peephole.cpp +++ b/src/gallium/drivers/nouveau/codegen/nv50_ir_peephole.cpp @@ -932,6 +932,24 @@ ConstantFolding::opnd(Instruction *i, ImmediateValue &imm0, int s) Instruction *newi = i; switch (i->op) { + case OP_SPLIT: { + bld.setPosition(i, false); + + uint8_t size = i->getDef(0)->reg.size; + uint32_t mask = (1ULL << size) - 1; + assert(size <= 32); + + uint64_t val = imm0.reg.data.u64; + for (int8_t d = 0; i->defExists(d); ++d) { + Value *def = i->getDef(d); + assert(def->reg.size == size); + + newi = bld.mkMov(def, bld.mkImm((uint32_t)(val & mask)), TYPE_U32); + val >>= size; + } + delete_Instruction(prog, i); + break; + } case OP_MUL: if (i->dType == TYPE_F32) tryCollapseChainedMULs(i, s, imm0);