From: Rob Clark <robcl...@freedesktop.org> We'll need this for a nir pass to lower builtin-uniform access.
Signed-off-by: Rob Clark <robcl...@freedesktop.org> --- src/compiler/glsl/builtin_variables.cpp | 24 +++++++++++++++--------- src/compiler/glsl/ir.h | 3 +++ 2 files changed, 18 insertions(+), 9 deletions(-) diff --git a/src/compiler/glsl/builtin_variables.cpp b/src/compiler/glsl/builtin_variables.cpp index 6db74f1..a9bc7d6 100644 --- a/src/compiler/glsl/builtin_variables.cpp +++ b/src/compiler/glsl/builtin_variables.cpp @@ -523,23 +523,29 @@ builtin_variable_generator::add_variable(const char *name, return var; } - -ir_variable * -builtin_variable_generator::add_uniform(const glsl_type *type, - const char *name) +extern "C" { +const struct gl_builtin_uniform_desc * +_mesa_glsl_get_builtin_uniform_desc(const char *name) { - ir_variable *const uni = add_variable(name, type, ir_var_uniform, -1); - unsigned i; for (i = 0; _mesa_builtin_uniform_desc[i].name != NULL; i++) { if (strcmp(_mesa_builtin_uniform_desc[i].name, name) == 0) { - break; + return &_mesa_builtin_uniform_desc[i]; } } + return NULL; +} +} + +ir_variable * +builtin_variable_generator::add_uniform(const glsl_type *type, + const char *name) +{ + ir_variable *const uni = add_variable(name, type, ir_var_uniform, -1); - assert(_mesa_builtin_uniform_desc[i].name != NULL); const struct gl_builtin_uniform_desc* const statevar = - &_mesa_builtin_uniform_desc[i]; + _mesa_glsl_get_builtin_uniform_desc(name); + assert(statevar != NULL); const unsigned array_count = type->is_array() ? type->length : 1; diff --git a/src/compiler/glsl/ir.h b/src/compiler/glsl/ir.h index bd7b550..f6e9d47 100644 --- a/src/compiler/glsl/ir.h +++ b/src/compiler/glsl/ir.h @@ -2622,6 +2622,9 @@ extern void _mesa_print_ir(FILE *f, struct exec_list *instructions, extern void fprint_ir(FILE *f, const void *instruction); +extern const struct gl_builtin_uniform_desc * +_mesa_glsl_get_builtin_uniform_desc(const char *name); + #ifdef __cplusplus } /* extern "C" */ #endif -- 2.5.0 _______________________________________________ mesa-dev mailing list mesa-dev@lists.freedesktop.org http://lists.freedesktop.org/mailman/listinfo/mesa-dev