From: Francisco Jerez Date: Sun, 16 Aug 2015 22:27:43 +0000 (+0300) Subject: glsl: Implement GLSL ES restriction on images being either readonly or writeonly. X-Git-Tag: upstream/17.1.0~16771 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=ee7bf349d865b18ca2827508fb947b7e549c7fc6;p=platform%2Fupstream%2Fmesa.git glsl: Implement GLSL ES restriction on images being either readonly or writeonly. Reviewed-by: Tapani Pälli --- diff --git a/src/glsl/ast_to_hir.cpp b/src/glsl/ast_to_hir.cpp index 4d279f6..ff57ec3 100644 --- a/src/glsl/ast_to_hir.cpp +++ b/src/glsl/ast_to_hir.cpp @@ -2469,6 +2469,24 @@ apply_image_qualifier_to_variable(const struct ast_type_qualifier *qual, var->data.image_format = GL_NONE; } + + /* From page 70 of the GLSL ES 3.1 specification: + * + * "Except for image variables qualified with the format qualifiers + * r32f, r32i, and r32ui, image variables must specify either memory + * qualifier readonly or the memory qualifier writeonly." + */ + if (state->es_shader && + var->data.image_format != GL_R32F && + var->data.image_format != GL_R32I && + var->data.image_format != GL_R32UI && + !var->data.image_read_only && + !var->data.image_write_only) { + _mesa_glsl_error(loc, state, "image variables of format other than " + "r32f, r32i or r32ui must be qualified `readonly' or " + "`writeonly'"); + } + } else if (qual->flags.q.read_only || qual->flags.q.write_only || qual->flags.q.coherent ||