i965/vs: Apply the gen6 math workaround for math1 instructions.
authorEric Anholt <eric@anholt.net>
Sat, 6 Aug 2011 03:16:21 +0000 (20:16 -0700)
committerEric Anholt <eric@anholt.net>
Tue, 16 Aug 2011 20:04:42 +0000 (13:04 -0700)
Fixes glsl-vs-masked-cos.

src/mesa/drivers/dri/i965/brw_vec4_visitor.cpp

index 4237373c13db9801fe1ed40661a8d62637902670..7e0535b5c023310285d8b128470b1aae263e7ee7 100644 (file)
@@ -122,14 +122,12 @@ vec4_visitor::emit_math1_gen6(enum opcode opcode, dst_reg dst, src_reg src)
 {
    /* The gen6 math instruction ignores the source modifiers --
     * swizzle, abs, negate, and at least some parts of the register
-    * region description.  Move the source to the corresponding slots
-    * of the destination generally work.
+    * region description.
     */
-   src_reg expanded = src_reg(this, glsl_type::float_type);
-   emit(BRW_OPCODE_MOV, dst, src);
-   src = expanded;
+   src_reg temp_src = src_reg(this, glsl_type::vec4_type);
+   emit(BRW_OPCODE_MOV, dst_reg(temp_src), src);
 
-   emit(opcode, dst, src);
+   emit(opcode, dst, temp_src);
 }
 
 void