glsl_to_tgsi: emit both operands of shift and bitwise operations
authorBryan Cain <bryancain3@gmail.com>
Tue, 13 Dec 2011 16:30:59 +0000 (10:30 -0600)
committerBryan Cain <bryancain3@gmail.com>
Tue, 13 Dec 2011 16:39:52 +0000 (10:39 -0600)
Fixes these operations when native integers are enabled.

src/mesa/state_tracker/st_glsl_to_tgsi.cpp

index 6cc655d70cf5f95b79f9ff36df30aef204e7b8e8..9042cdb2f983b7ab8789b29f9a2347954d81df68 100644 (file)
@@ -1807,27 +1807,27 @@ glsl_to_tgsi_visitor::visit(ir_expression *ir)
       }
    case ir_binop_lshift:
       if (native_integers) {
-         emit(ir, TGSI_OPCODE_SHL, result_dst, op[0]);
+         emit(ir, TGSI_OPCODE_SHL, result_dst, op[0], op[1]);
          break;
       }
    case ir_binop_rshift:
       if (native_integers) {
-         emit(ir, TGSI_OPCODE_ISHR, result_dst, op[0]);
+         emit(ir, TGSI_OPCODE_ISHR, result_dst, op[0], op[1]);
          break;
       }
    case ir_binop_bit_and:
       if (native_integers) {
-         emit(ir, TGSI_OPCODE_AND, result_dst, op[0]);
+         emit(ir, TGSI_OPCODE_AND, result_dst, op[0], op[1]);
          break;
       }
    case ir_binop_bit_xor:
       if (native_integers) {
-         emit(ir, TGSI_OPCODE_XOR, result_dst, op[0]);
+         emit(ir, TGSI_OPCODE_XOR, result_dst, op[0], op[1]);
          break;
       }
    case ir_binop_bit_or:
       if (native_integers) {
-         emit(ir, TGSI_OPCODE_OR, result_dst, op[0]);
+         emit(ir, TGSI_OPCODE_OR, result_dst, op[0], op[1]);
          break;
       }
    case ir_unop_round_even: