diff options
author | Dave Airlie <[email protected]> | 2016-05-23 12:14:01 +1000 |
---|---|---|
committer | Dave Airlie <[email protected]> | 2016-05-30 11:25:30 +1000 |
commit | 6effdce92e89890f7276d406607241b7e372d1be (patch) | |
tree | 55704daed47825d5e476a4b4e1d08b1e613c5493 /src/compiler/glsl/ast_to_hir.cpp | |
parent | db2a35193fc8e08b2bb54bf9f6150a9fc054b178 (diff) |
glsl/ast: subroutineTypes can't be returned from functions.
These types can't be returned.
This fixes:
GL43-CTS.shader_subroutine.subroutines_not_allowed_as_variables_constructors_and_argument_or_return_types
for the return type case.
Reviewed-by: Chris Forbes <[email protected]>
Signed-off-by: Dave Airlie <[email protected]>
Diffstat (limited to 'src/compiler/glsl/ast_to_hir.cpp')
-rw-r--r-- | src/compiler/glsl/ast_to_hir.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/src/compiler/glsl/ast_to_hir.cpp b/src/compiler/glsl/ast_to_hir.cpp index d6f9a750de7..ccacd266bb4 100644 --- a/src/compiler/glsl/ast_to_hir.cpp +++ b/src/compiler/glsl/ast_to_hir.cpp @@ -5400,6 +5400,15 @@ ast_function::hir(exec_list *instructions, name); } + /**/ + if (return_type->is_subroutine()) { + YYLTYPE loc = this->get_location(); + _mesa_glsl_error(&loc, state, + "function `%s' return type can't be a subroutine type", + name); + } + + /* Create an ir_function if one doesn't already exist. */ f = state->symbols->get_function(name); if (f == NULL) { |