From: Dave Airlie Date: Mon, 23 May 2016 02:49:25 +0000 (+1000) Subject: glsl/images: bounds check image unit assignment X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f87352d76966b6e4b0ab5fa9129ccd1ade0c2e7a;p=mesa.git glsl/images: bounds check image unit assignment The CTS test: GL45-CTS.multi_bind.dispatch_bind_image_textures binds 192 image uniforms, we reject this later, but not until after we trash the contents of the struct gl_shader. Error now reads: Too many compute shader image uniforms (192 > 16) instead of Too many compute shader image uniforms (2745344416 > 16) Reviewed-by: Ilia Mirkin Cc: "12.0" Signed-off-by: Dave Airlie --- diff --git a/src/compiler/glsl/link_uniform_initializers.cpp b/src/compiler/glsl/link_uniform_initializers.cpp index c6346d573ab..bf6d394ea89 100644 --- a/src/compiler/glsl/link_uniform_initializers.cpp +++ b/src/compiler/glsl/link_uniform_initializers.cpp @@ -145,6 +145,8 @@ set_opaque_binding(void *mem_ctx, gl_shader_program *prog, storage->opaque[sh].active) { for (unsigned i = 0; i < elements; i++) { const unsigned index = storage->opaque[sh].index + i; + if (index >= ARRAY_SIZE(shader->ImageUnits)) + break; shader->ImageUnits[index] = storage->storage[i].i; } }