glsl: Extend ir_expression_operation for GLSL 3.00 pack/unpack functions (v2)

For each function {pack,unpack}{Snorm,Unorm,Half}2x16, add a corresponding
opcode to enum ir_expression_operation.  Validate the new opcodes in
ir_validate.cpp.

Also, add opcodes for scalarized variants of the Half2x16 functions.  (The
code generator for the i965 fragment shader requires that all vector
operations be scalarized.  A lowering pass, to be added later, will
scalarize the Half2x16 functions).

v2: Fix assertion message in ir_to_mesa [for idr].

Reviewed-by: Ian Romanick <ian.d.romanick@intel.com>
Reviewed-by: Matt Tuner <mattst88@gmail.com>
Signed-off-by: Chad Versace <chad.versace@linux.intel.com>
This commit is contained in:
Chad Versace
2012-11-19 10:48:25 -08:00
parent 3a88d71d35
commit ee5921ad0d
4 changed files with 95 additions and 1 deletions

View File

@@ -306,6 +306,8 @@ ir_expression::ir_expression(int op, ir_rvalue *op0)
break; break;
case ir_unop_noise: case ir_unop_noise:
case ir_unop_unpack_half_2x16_split_x:
case ir_unop_unpack_half_2x16_split_y:
this->type = glsl_type::float_type; this->type = glsl_type::float_type;
break; break;
@@ -313,6 +315,18 @@ ir_expression::ir_expression(int op, ir_rvalue *op0)
this->type = glsl_type::bool_type; this->type = glsl_type::bool_type;
break; break;
case ir_unop_pack_snorm_2x16:
case ir_unop_pack_unorm_2x16:
case ir_unop_pack_half_2x16:
this->type = glsl_type::uint_type;
break;
case ir_unop_unpack_snorm_2x16:
case ir_unop_unpack_unorm_2x16:
case ir_unop_unpack_half_2x16:
this->type = glsl_type::vec2_type;
break;
default: default:
assert(!"not reached: missing automatic type setup for ir_expression"); assert(!"not reached: missing automatic type setup for ir_expression");
this->type = op0->type; this->type = op0->type;
@@ -386,6 +400,10 @@ ir_expression::ir_expression(int op, ir_rvalue *op0, ir_rvalue *op1)
this->type = glsl_type::float_type; this->type = glsl_type::float_type;
break; break;
case ir_binop_pack_half_2x16_split:
this->type = glsl_type::uint_type;
break;
case ir_binop_lshift: case ir_binop_lshift:
case ir_binop_rshift: case ir_binop_rshift:
this->type = op0->type; this->type = op0->type;
@@ -454,6 +472,14 @@ static const char *const operator_strs[] = {
"cos_reduced", "cos_reduced",
"dFdx", "dFdx",
"dFdy", "dFdy",
"packSnorm2x16",
"packUnorm2x16",
"packHalf2x16",
"unpackSnorm2x16",
"unpackUnorm2x16",
"unpackHalf2x16",
"unpackHalf2x16_split_x",
"unpackHalf2x16_split_y",
"noise", "noise",
"+", "+",
"-", "-",
@@ -480,6 +506,7 @@ static const char *const operator_strs[] = {
"min", "min",
"max", "max",
"pow", "pow",
"packHalf2x16_split",
"ubo_load", "ubo_load",
"vector", "vector",
}; };

View File

@@ -971,6 +971,28 @@ enum ir_expression_operation {
ir_unop_dFdy, ir_unop_dFdy,
/*@}*/ /*@}*/
/**
* \name Floating point pack and unpack operations.
*/
/*@{*/
ir_unop_pack_snorm_2x16,
ir_unop_pack_unorm_2x16,
ir_unop_pack_half_2x16,
ir_unop_unpack_snorm_2x16,
ir_unop_unpack_unorm_2x16,
ir_unop_unpack_half_2x16,
/*@}*/
/**
* \name Lowered floating point unpacking operations.
*
* \see lower_packing_builtins_visitor::split_unpack_half_2x16
*/
/*@{*/
ir_unop_unpack_half_2x16_split_x,
ir_unop_unpack_half_2x16_split_y,
/*@}*/
ir_unop_noise, ir_unop_noise,
/** /**
@@ -1037,6 +1059,15 @@ enum ir_expression_operation {
ir_binop_pow, ir_binop_pow,
/**
* \name Lowered floating point packing operations.
*
* \see lower_packing_builtins_visitor::split_pack_half_2x16
*/
/*@{*/
ir_binop_pack_half_2x16_split,
/*@}*/
/** /**
* Load a value the size of a given GLSL type from a uniform block. * Load a value the size of a given GLSL type from a uniform block.
* *

View File

@@ -329,6 +329,26 @@ ir_validate::visit_leave(ir_expression *ir)
assert(ir->operands[0]->type == ir->type); assert(ir->operands[0]->type == ir->type);
break; break;
case ir_unop_pack_snorm_2x16:
case ir_unop_pack_unorm_2x16:
case ir_unop_pack_half_2x16:
assert(ir->type == glsl_type::uint_type);
assert(ir->operands[0]->type == glsl_type::vec2_type);
break;
case ir_unop_unpack_snorm_2x16:
case ir_unop_unpack_unorm_2x16:
case ir_unop_unpack_half_2x16:
assert(ir->type == glsl_type::vec2_type);
assert(ir->operands[0]->type == glsl_type::uint_type);
break;
case ir_unop_unpack_half_2x16_split_x:
case ir_unop_unpack_half_2x16_split_y:
assert(ir->type == glsl_type::float_type);
assert(ir->operands[0]->type == glsl_type::uint_type);
break;
case ir_unop_noise: case ir_unop_noise:
/* XXX what can we assert here? */ /* XXX what can we assert here? */
break; break;
@@ -423,6 +443,12 @@ ir_validate::visit_leave(ir_expression *ir)
assert(ir->operands[0]->type == ir->operands[1]->type); assert(ir->operands[0]->type == ir->operands[1]->type);
break; break;
case ir_binop_pack_half_2x16_split:
assert(ir->type == glsl_type::uint_type);
assert(ir->operands[0]->type == glsl_type::float_type);
assert(ir->operands[1]->type == glsl_type::float_type);
break;
case ir_binop_ubo_load: case ir_binop_ubo_load:
assert(ir->operands[0]->as_constant()); assert(ir->operands[0]->as_constant());
assert(ir->operands[0]->type == glsl_type::uint_type); assert(ir->operands[0]->type == glsl_type::uint_type);

View File

@@ -1427,7 +1427,17 @@ ir_to_mesa_visitor::visit(ir_expression *ir)
case ir_unop_fract: case ir_unop_fract:
emit(ir, OPCODE_FRC, result_dst, op[0]); emit(ir, OPCODE_FRC, result_dst, op[0]);
break; break;
case ir_unop_pack_snorm_2x16:
case ir_unop_pack_unorm_2x16:
case ir_unop_pack_half_2x16:
case ir_unop_unpack_snorm_2x16:
case ir_unop_unpack_unorm_2x16:
case ir_unop_unpack_half_2x16:
case ir_unop_unpack_half_2x16_split_x:
case ir_unop_unpack_half_2x16_split_y:
case ir_binop_pack_half_2x16_split:
assert(!"not supported");
break;
case ir_binop_min: case ir_binop_min:
emit(ir, OPCODE_MIN, result_dst, op[0], op[1]); emit(ir, OPCODE_MIN, result_dst, op[0], op[1]);
break; break;