r300-gallium: vs: Add MAD.
authorCorbin Simpson <MostAwesomeDude@gmail.com>
Tue, 7 Apr 2009 06:36:34 +0000 (23:36 -0700)
committerCorbin Simpson <MostAwesomeDude@gmail.com>
Tue, 7 Apr 2009 06:36:34 +0000 (23:36 -0700)
src/gallium/drivers/r300/r300_state_tcl.c
src/gallium/drivers/r300/r300_state_tcl.h

index 24e522ce8bea2abe3d7db4595bc70d1a1bfb462c..44365f563c42706effe508165bf5b8ce98158e80 100644 (file)
@@ -121,6 +121,8 @@ static uint32_t r300_vs_op(unsigned op)
         case TGSI_OPCODE_MOV:
         case TGSI_OPCODE_SWZ:
             return R300_VE_ADD;
+        case TGSI_OPCODE_MAD:
+            return R300_PVS_DST_MACRO_INST | R300_PVS_MACRO_OP_2CLK_MADD;
         default:
             break;
     }
@@ -198,6 +200,11 @@ static void r300_vs_instruction(struct r300_vertex_shader* vs,
                     &inst->FullDstRegisters[0], inst->Instruction.Opcode,
                     2);
             break;
+        case TGSI_OPCODE_MAD:
+            r300_vs_emit_inst(vs, assembler, inst->FullSrcRegisters,
+                    &inst->FullDstRegisters[0], inst->Instruction.Opcode,
+                    3);
+            break;
         case TGSI_OPCODE_END:
             break;
         default:
index cbad1c31fdb0df8bf07e3d014f9ddfcc0f2772da..3d10e248e15a055a4b0645c59db5c3aff875ff95 100644 (file)
@@ -34,6 +34,8 @@
 #define R300_PVS_DST_OPCODE(x)   ((x) << 0)
 #   define R300_VE_MULTIPLY               2
 #   define R300_VE_ADD                    3
+#define R300_PVS_DST_MACRO_INST    (1 << 7)
+#   define R300_PVS_MACRO_OP_2CLK_MADD    0
 #define R300_PVS_DST_REG_TYPE(x) ((x) << 8)
 #   define R300_PVS_DST_REG_TEMPORARY     0
 #   define R300_PVS_DST_REG_A0            1