From 90b5301ceab8fd86fccf76efe7ebb039c0e4a28f Mon Sep 17 00:00:00 2001 From: Christoph Bumiller Date: Wed, 18 Apr 2012 17:00:52 +0200 Subject: nv50/ir/opt: swap VP inputs to first source where possible --- src/gallium/drivers/nv50/codegen/nv50_ir_peephole.cpp | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/src/gallium/drivers/nv50/codegen/nv50_ir_peephole.cpp b/src/gallium/drivers/nv50/codegen/nv50_ir_peephole.cpp index 3852a8de3d0..7d0ebc69710 100644 --- a/src/gallium/drivers/nv50/codegen/nv50_ir_peephole.cpp +++ b/src/gallium/drivers/nv50/codegen/nv50_ir_peephole.cpp @@ -123,6 +123,7 @@ private: bool isCSpaceLoad(Instruction *); bool isImmd32Load(Instruction *); + bool isAttribOrSharedLoad(Instruction *); }; bool @@ -139,6 +140,16 @@ LoadPropagation::isImmd32Load(Instruction *ld) return ld->src(0).getFile() == FILE_IMMEDIATE; } +bool +LoadPropagation::isAttribOrSharedLoad(Instruction *ld) +{ + return ld && + (ld->op == OP_VFETCH || + (ld->op == OP_LOAD && + (ld->src(0).getFile() == FILE_SHADER_INPUT || + ld->src(0).getFile() == FILE_MEMORY_SHARED))); +} + void LoadPropagation::checkSwapSrc01(Instruction *insn) { @@ -162,6 +173,12 @@ LoadPropagation::checkSwapSrc01(Instruction *insn) insn->swapSources(0, 1); else return; + } else + if (isAttribOrSharedLoad(i1)) { + if (!isAttribOrSharedLoad(i0)) + insn->swapSources(0, 1); + else + return; } else { return; } -- cgit v1.2.3