nv50/ir: propagate modifier to right arg when const-folding mad
authorIlia Mirkin <imirkin@alum.mit.edu>
Fri, 26 Jun 2015 19:01:22 +0000 (15:01 -0400)
committerIlia Mirkin <imirkin@alum.mit.edu>
Fri, 26 Jun 2015 22:42:29 +0000 (18:42 -0400)
An immediate has to be the second arg of an ADD operation. However we
were mistakenly propagating the modifier of the non-folded value to the
folded immediate argument.

Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=91117
Signed-off-by: Ilia Mirkin <imirkin@alum.mit.edu>
Cc: "10.5 10.6" <mesa-stable@lists.freedesktop.org>
src/gallium/drivers/nouveau/codegen/nv50_ir_peephole.cpp

index ae739eeda83c63b460759de2cdf398f2270b40e5..ad9bf6f4aa9aed2804c0df76151dbbb3ab1680e0 100644 (file)
@@ -608,9 +608,12 @@ ConstantFolding::expr(Instruction *i,
    case OP_FMA: {
       i->op = OP_ADD;
 
+      /* Move the immediate to the second arg, otherwise the ADD operation
+       * won't be emittable
+       */
       i->setSrc(1, i->getSrc(0));
-      i->src(1).mod = i->src(2).mod;
       i->setSrc(0, i->getSrc(2));
+      i->src(0).mod = i->src(2).mod;
       i->setSrc(2, NULL);
 
       ImmediateValue src0;