break;
case ir_unop_f2b:
+ inst = emit(BRW_OPCODE_CMP, this->result, op[0], fs_reg(0.0f));
+ inst->conditional_mod = BRW_CONDITIONAL_NZ;
+ emit(BRW_OPCODE_AND, this->result, this->result, fs_reg(1));
+ break;
case ir_unop_i2b:
- temp = this->result;
- /* original gen4 does implicit conversion before comparison. */
- if (intel->gen < 5)
- temp.type = op[0].type;
-
- resolve_ud_negate(&op[0]);
+ assert(op[0].type == BRW_REGISTER_TYPE_D);
- inst = emit(BRW_OPCODE_CMP, temp, op[0], fs_reg(0.0f));
+ inst = emit(BRW_OPCODE_CMP, this->result, op[0], fs_reg(0));
inst->conditional_mod = BRW_CONDITIONAL_NZ;
+ emit(BRW_OPCODE_AND, this->result, this->result, fs_reg(1));
break;
case ir_unop_trunc: