From: Chris Forbes Date: Sun, 10 Nov 2013 08:19:31 +0000 (+1300) Subject: allow builtin functions to require parameters to be shader inputs X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=8b7a323596992a2a2127f40d2d4cae1e9fb0a94d;p=mesa.git allow builtin functions to require parameters to be shader inputs The new interpolateAt* builtins have strange restrictions on the parameter. - It must be a shader input, or an element of a shader input array. - It must not include a swizzle. V2: Don't abuse ir_var_mode_shader_in for this; make a new flag. Signed-off-by: Chris Forbes Reviewed-by: Ilia Mirkin --- diff --git a/src/glsl/ast_function.cpp b/src/glsl/ast_function.cpp index cdb34cc6988..631b793c830 100644 --- a/src/glsl/ast_function.cpp +++ b/src/glsl/ast_function.cpp @@ -178,6 +178,24 @@ verify_parameter_modes(_mesa_glsl_parse_state *state, return false; } + /* Verify that shader_in parameters are shader inputs */ + if (formal->data.must_be_shader_input) { + ir_variable *var = actual->variable_referenced(); + if (var && var->data.mode != ir_var_shader_in) { + _mesa_glsl_error(&loc, state, + "parameter `%s` must be a shader input", + formal->name); + return false; + } + + if (actual->ir_type == ir_type_swizzle) { + _mesa_glsl_error(&loc, state, + "parameter `%s` must not be swizzled", + formal->name); + return false; + } + } + /* Verify that 'out' and 'inout' actual parameters are lvalues. */ if (formal->data.mode == ir_var_function_out || formal->data.mode == ir_var_function_inout) { diff --git a/src/glsl/ir.h b/src/glsl/ir.h index d5239d4de1b..fa93efd2de1 100644 --- a/src/glsl/ir.h +++ b/src/glsl/ir.h @@ -677,6 +677,12 @@ public: */ unsigned from_named_ifc_block_array:1; + /** + * Non-zero if the variable must be a shader input. This is useful for + * constraints on function parameters. + */ + unsigned must_be_shader_input:1; + /** * \brief Layout qualifier for gl_FragDepth. *