From: Dave Airlie Date: Tue, 3 May 2016 04:33:16 +0000 (+1000) Subject: glsl: subroutine types cannot be used in constructors. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=265fe9dce8727d8777153fa9846300051141a88e;p=mesa.git glsl: subroutine types cannot be used in constructors. This fixes two of the cases in GL43-CTS.shader_subroutine.subroutines_not_allowed_as_variables_constructors_and_argument_or_return_types Reviewed-by: Iago Toral Quiroga Signed-off-by: Dave Airlie --- diff --git a/src/compiler/glsl/ast_function.cpp b/src/compiler/glsl/ast_function.cpp index f50c7bf7b71..37fb3e790c4 100644 --- a/src/compiler/glsl/ast_function.cpp +++ b/src/compiler/glsl/ast_function.cpp @@ -1819,6 +1819,12 @@ ast_function_expression::hir(exec_list *instructions, return ir_rvalue::error_value(ctx); } + if (constructor_type->is_subroutine()) { + _mesa_glsl_error(& loc, state, "subroutine name cannot be a constructor `%s'", + constructor_type->name); + return ir_rvalue::error_value(ctx); + } + if (constructor_type->is_array()) { if (!state->check_version(120, 300, &loc, "array constructors forbidden")) {