glsl2: Make cross() be an expression operation.
ARB_fp, ARB_vp, Mesa IR, and the 965 vertex shader all have instructions for cross. Shaves 12 Mesa instructions off of a 66-instruction shader I have.
This commit is contained in:
@@ -486,17 +486,7 @@ static const char *builtins_110_cross = {
|
|||||||
" (parameters\n"
|
" (parameters\n"
|
||||||
" (declare (in) vec3 arg0)\n"
|
" (declare (in) vec3 arg0)\n"
|
||||||
" (declare (in) vec3 arg1))\n"
|
" (declare (in) vec3 arg1))\n"
|
||||||
" ((declare () vec3 t)\n"
|
" ((return (expression vec3 cross (var_ref arg0) (var_ref arg1)))))\n"
|
||||||
" (assign (constant bool (1)) (swiz x (var_ref t))\n"
|
|
||||||
" (expression float - (expression float * (swiz y (var_ref arg0)) (swiz z (var_ref arg1)))\n"
|
|
||||||
" (expression float * (swiz y (var_ref arg1)) (swiz z (var_ref arg0)))))\n"
|
|
||||||
" (assign (constant bool (1)) (swiz y (var_ref t))\n"
|
|
||||||
" (expression float - (expression float * (swiz z (var_ref arg0)) (swiz x (var_ref arg1)))\n"
|
|
||||||
" (expression float * (swiz z (var_ref arg1)) (swiz x (var_ref arg0)))))\n"
|
|
||||||
" (assign (constant bool (1)) (swiz z (var_ref t))\n"
|
|
||||||
" (expression float - (expression float * (swiz x (var_ref arg0)) (swiz y (var_ref arg1)))\n"
|
|
||||||
" (expression float * (swiz x (var_ref arg1)) (swiz y (var_ref arg0)))))\n"
|
|
||||||
" (return (var_ref t))))\n"
|
|
||||||
"))\n"
|
"))\n"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@@ -3,15 +3,5 @@
|
|||||||
(parameters
|
(parameters
|
||||||
(declare (in) vec3 arg0)
|
(declare (in) vec3 arg0)
|
||||||
(declare (in) vec3 arg1))
|
(declare (in) vec3 arg1))
|
||||||
((declare () vec3 t)
|
((return (expression vec3 cross (var_ref arg0) (var_ref arg1)))))
|
||||||
(assign (constant bool (1)) (swiz x (var_ref t))
|
|
||||||
(expression float - (expression float * (swiz y (var_ref arg0)) (swiz z (var_ref arg1)))
|
|
||||||
(expression float * (swiz y (var_ref arg1)) (swiz z (var_ref arg0)))))
|
|
||||||
(assign (constant bool (1)) (swiz y (var_ref t))
|
|
||||||
(expression float - (expression float * (swiz z (var_ref arg0)) (swiz x (var_ref arg1)))
|
|
||||||
(expression float * (swiz z (var_ref arg1)) (swiz x (var_ref arg0)))))
|
|
||||||
(assign (constant bool (1)) (swiz z (var_ref t))
|
|
||||||
(expression float - (expression float * (swiz x (var_ref arg0)) (swiz y (var_ref arg1)))
|
|
||||||
(expression float * (swiz x (var_ref arg1)) (swiz y (var_ref arg0)))))
|
|
||||||
(return (var_ref t))))
|
|
||||||
))
|
))
|
||||||
|
@@ -104,6 +104,7 @@ ir_expression::get_num_operands(ir_expression_operation op)
|
|||||||
2, /* ir_binop_logic_or */
|
2, /* ir_binop_logic_or */
|
||||||
|
|
||||||
2, /* ir_binop_dot */
|
2, /* ir_binop_dot */
|
||||||
|
2, /* ir_binop_cross */
|
||||||
2, /* ir_binop_min */
|
2, /* ir_binop_min */
|
||||||
2, /* ir_binop_max */
|
2, /* ir_binop_max */
|
||||||
|
|
||||||
@@ -163,6 +164,7 @@ static const char *const operator_strs[] = {
|
|||||||
"^^",
|
"^^",
|
||||||
"||",
|
"||",
|
||||||
"dot",
|
"dot",
|
||||||
|
"cross",
|
||||||
"min",
|
"min",
|
||||||
"max",
|
"max",
|
||||||
"pow",
|
"pow",
|
||||||
|
@@ -609,6 +609,7 @@ enum ir_expression_operation {
|
|||||||
ir_binop_logic_or,
|
ir_binop_logic_or,
|
||||||
|
|
||||||
ir_binop_dot,
|
ir_binop_dot,
|
||||||
|
ir_binop_cross,
|
||||||
ir_binop_min,
|
ir_binop_min,
|
||||||
ir_binop_max,
|
ir_binop_max,
|
||||||
|
|
||||||
|
@@ -459,8 +459,19 @@ ir_constant_visitor::visit(ir_expression *ir)
|
|||||||
assert(0);
|
assert(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case ir_binop_cross:
|
||||||
|
assert(op[0]->type == glsl_type::vec3_type);
|
||||||
|
assert(op[1]->type == glsl_type::vec3_type);
|
||||||
|
data.f[0] = (op[0]->value.f[1] * op[1]->value.f[2] -
|
||||||
|
op[1]->value.f[1] * op[0]->value.f[2]);
|
||||||
|
data.f[1] = (op[0]->value.f[2] * op[1]->value.f[0] -
|
||||||
|
op[1]->value.f[2] * op[0]->value.f[0]);
|
||||||
|
data.f[2] = (op[0]->value.f[0] * op[1]->value.f[1] -
|
||||||
|
op[1]->value.f[0] * op[0]->value.f[1]);
|
||||||
|
break;
|
||||||
|
|
||||||
case ir_binop_add:
|
case ir_binop_add:
|
||||||
assert(op[0]->type == op[1]->type || op0_scalar || op1_scalar);
|
assert(op[0]->type == op[1]->type || op0_scalar || op1_scalar);
|
||||||
for (unsigned c = 0, c0 = 0, c1 = 0;
|
for (unsigned c = 0, c0 = 0, c1 = 0;
|
||||||
|
@@ -781,6 +781,11 @@ ir_to_mesa_visitor::visit(ir_expression *ir)
|
|||||||
op[0], op[1]);
|
op[0], op[1]);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case ir_binop_cross:
|
||||||
|
ir_to_mesa_emit_op2(ir, OPCODE_XPD, result_dst, op[0], op[1]);
|
||||||
|
break;
|
||||||
|
|
||||||
case ir_unop_sqrt:
|
case ir_unop_sqrt:
|
||||||
ir_to_mesa_emit_scalar_op1(ir, OPCODE_RSQ, result_dst, op[0]);
|
ir_to_mesa_emit_scalar_op1(ir, OPCODE_RSQ, result_dst, op[0]);
|
||||||
ir_to_mesa_emit_scalar_op1(ir, OPCODE_RCP, result_dst, result_src);
|
ir_to_mesa_emit_scalar_op1(ir, OPCODE_RCP, result_dst, result_src);
|
||||||
|
Reference in New Issue
Block a user