summaryrefslogtreecommitdiff
path: root/src/mesa/shader/slang
diff options
context:
space:
mode:
authorBrian Paul <brian.paul@tungstengraphics.com>2008-12-09 14:30:42 -0700
committerBrian Paul <brian.paul@tungstengraphics.com>2008-12-09 14:30:42 -0700
commite8f5c1a5e89fe43ddfa277d7392dcaf8ac1d6c88 (patch)
tree2b02424a13f7cedaa1fc3f92cd7ed5081e6c4279 /src/mesa/shader/slang
parent3c7419d57b042cdec7753fe4799e56002009102b (diff)
mesa: in slang linker, replace assertion with link error when max samplers exceeded
Diffstat (limited to 'src/mesa/shader/slang')
-rw-r--r--src/mesa/shader/slang/slang_link.c24
1 files changed, 18 insertions, 6 deletions
diff --git a/src/mesa/shader/slang/slang_link.c b/src/mesa/shader/slang/slang_link.c
index 08d7540372..834f05176c 100644
--- a/src/mesa/shader/slang/slang_link.c
+++ b/src/mesa/shader/slang/slang_link.c
@@ -207,7 +207,7 @@ link_varying_vars(struct gl_shader_program *shProg, struct gl_program *prog)
* This is basically a list/index of all uniforms found in either/both of
* the vertex and fragment shaders.
*/
-static void
+static GLboolean
link_uniform_vars(struct gl_shader_program *shProg,
struct gl_program *prog,
GLuint *numSamplers)
@@ -239,7 +239,10 @@ link_uniform_vars(struct gl_shader_program *shProg,
/* Allocate a new sampler index */
GLuint sampNum = *numSamplers;
GLuint oldSampNum = (GLuint) prog->Parameters->ParameterValues[i][0];
- assert(oldSampNum < MAX_SAMPLERS);
+ if (oldSampNum >= MAX_SAMPLERS) {
+ link_error(shProg, "Too many texture samplers");
+ return GL_FALSE;
+ }
samplerMap[oldSampNum] = sampNum;
(*numSamplers)++;
}
@@ -265,6 +268,7 @@ link_uniform_vars(struct gl_shader_program *shProg,
}
}
+ return GL_TRUE;
}
@@ -560,10 +564,18 @@ _slang_link(GLcontext *ctx,
}
/* link uniform vars */
- if (shProg->VertexProgram)
- link_uniform_vars(shProg, &shProg->VertexProgram->Base, &numSamplers);
- if (shProg->FragmentProgram)
- link_uniform_vars(shProg, &shProg->FragmentProgram->Base, &numSamplers);
+ if (shProg->VertexProgram) {
+ if (!link_uniform_vars(shProg, &shProg->VertexProgram->Base,
+ &numSamplers)) {
+ return;
+ }
+ }
+ if (shProg->FragmentProgram) {
+ if (!link_uniform_vars(shProg, &shProg->FragmentProgram->Base,
+ &numSamplers)) {
+ return;
+ }
+ }
/*_mesa_print_uniforms(shProg->Uniforms);*/