aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--video/out/opengl/utils.c19
1 files changed, 13 insertions, 6 deletions
diff --git a/video/out/opengl/utils.c b/video/out/opengl/utils.c
index 02f1ea6584..288e552521 100644
--- a/video/out/opengl/utils.c
+++ b/video/out/opengl/utils.c
@@ -544,6 +544,7 @@ struct sc_uniform {
struct sc_entry {
GLuint gl_shader;
+ GLint uniform_locs[SC_UNIFORM_ENTRIES];
// the following fields define the shader's contents
char *key; // vertex+frag shader (mangled)
struct gl_vao *vao;
@@ -797,14 +798,13 @@ static const char *vao_glsl_type(const struct gl_vao_entry *e)
}
// Assumes program is current (gl->UseProgram(program)).
-static void update_uniform(GL *gl, GLuint program, struct sc_uniform *u)
+static void update_uniform(GL *gl, GLuint program, struct sc_uniform *u, GLint loc)
{
if (u->type == UT_buffer) {
GLuint idx = gl->GetUniformBlockIndex(program, u->name);
gl->UniformBlockBinding(program, idx, u->v.buffer.binding);
return;
}
- GLint loc = gl->GetUniformLocation(program, u->name);
if (loc < 0)
return;
switch (u->type) {
@@ -1008,16 +1008,23 @@ void gl_sc_gen_shader_and_reset(struct gl_shader_cache *sc)
entry = &sc->entries[sc->num_entries++];
*entry = (struct sc_entry){.key = talloc_strdup(NULL, key)};
}
- // build vertex shader from vao
- if (!entry->gl_shader)
+ // build vertex shader from vao and cache the locations of the uniform variables
+ if (!entry->gl_shader) {
entry->gl_shader = create_program(sc, vert, frag);
+ for (int n = 0; n < sc->num_uniforms; n++) {
+ entry->uniform_locs[n] = gl->GetUniformLocation(entry->gl_shader,
+ sc->uniforms[n].name);
+ }
+ }
gl->UseProgram(entry->gl_shader);
// For now we set the uniforms every time. This is probably bad, and we
// should switch to caching them.
- for (int n = 0; n < sc->num_uniforms; n++)
- update_uniform(gl, entry->gl_shader, &sc->uniforms[n]);
+ for (int n = 0; n < sc->num_uniforms; n++) {
+ update_uniform(gl, entry->gl_shader, &sc->uniforms[n],
+ entry->uniform_locs[n]);
+ }
talloc_free(tmp);