[Mesa-dev] [Mesa-stable] [PATCH] glsl: Allow overlapping locations for vertex input attributes

Ian Romanick idr at freedesktop.org
Mon Mar 10 15:27:06 PDT 2014


On 03/10/2014 11:19 AM, Anuj Phogat wrote:
> Currently overlapping locations of input variables are not allowed for all
> the shader types in OpenGL and OpenGL ES.
> 
>>From OpenGL ES 3.0 spec, page 56:
>    "Binding more than one attribute name to the same location is referred
>     to as aliasing, and is not permitted in OpenGL ES Shading Language
>     3.00 vertex shaders. LinkProgram will fail when this condition exists.
>     However, aliasing is possible in OpenGL ES Shading Language 1.00 vertex
>     shaders."
> 
> Taking in to account what different versions of OpenGL and OpenGL ES specs
> say about aliasing:
>    - It is allowed only on vertex shader input attributes in OpenGL (2.0 and
>      above) and OpenGL ES 2.0.
>    - It is explictly disallowed in OpenGL ES 3.0.
> 
> Fixes Khronos CTS failing test:
> explicit_attrib_location_vertex_input_aliased.test
> See more details about this at below mentioned khronos bug.
> 
> Signed-off-by: Anuj Phogat <anuj.phogat at gmail.com>
> Cc: "9.2 10.0 10.1" <mesa-stable at lists.freedesktop.org>
> Bugzilla: Khronos #9609
> ---
>  src/glsl/linker.cpp | 74 +++++++++++++++++++++++++++++++++++++++++++----------
>  1 file changed, 61 insertions(+), 13 deletions(-)
> 
> diff --git a/src/glsl/linker.cpp b/src/glsl/linker.cpp
> index a619bc8..9bd698b 100644
> --- a/src/glsl/linker.cpp
> +++ b/src/glsl/linker.cpp
> @@ -1798,10 +1798,12 @@ assign_attribute_or_color_locations(gl_shader_program *prog,
>  	     *     active attribute array, both of which require multiple
>  	     *     contiguous generic attributes."
>  	     *
> -	     * Previous versions of the spec contain similar language but omit
> -	     * the bit about attribute arrays.
> +	     * I think above text prohibits the aliasing of explicit and
> +	     * automatic assignments. But, aliasing is allowed in manual
> +	     * assignments of attribute locations. See below comments for
> +	     * the details.

The text above (outside the diff) forbids things like:

layout(location=0) in mat4 m;
layout(location=1) in vec4 v;

where v and m now partially overlap because m consumes 4 slots (0
through 3, inclusive).

Does this patch affect this?

>  	     *
> -	     * Page 61 of the OpenGL 4.0 spec also says:
> +	     * From OpenGL 4.0 spec, page 61:
>  	     *
>  	     *     "It is possible for an application to bind more than one
>  	     *     attribute name to the same location. This is referred to as
> @@ -1814,12 +1816,48 @@ assign_attribute_or_color_locations(gl_shader_program *prog,
>  	     *     but implementations are not required to generate an error
>  	     *     in this case."
>  	     *
> -	     * These two paragraphs are either somewhat contradictory, or I
> -	     * don't fully understand one or both of them.
> -	     */
> -	    /* FINISHME: The code as currently written does not support
> -	     * FINISHME: attribute location aliasing (see comment above).
> +	     * From GLSL 4.30 spec, page 54:
> +	     *
> +	     *    "A program will fail to link if any two non-vertex shader
> +	     *     input variables are assigned to the same location. For
> +	     *     vertex shaders, multiple input variables may be assigned
> +	     *     to the same location using either layout qualifiers or via
> +	     *     the OpenGL API. However, such aliasing is intended only to
> +	     *     support vertex shaders where each execution path accesses
> +	     *     at most one input per each location. Implementations are
> +	     *     permitted, but not required, to generate link-time errors
> +	     *     if they detect that every path through the vertex shader
> +	     *     executable accesses multiple inputs assigned to any single
> +	     *     location. For all shader types, a program will fail to link
> +	     *     if explicit location assignments leave the linker unable
> +	     *     to find space for other variables without explicit
> +	     *     assignments."
> +	     *
> +	     * From OpenGL ES 3.0 spec, page 56:
> +	     *
> +	     *    "Binding more than one attribute name to the same location
> +	     *     is referred to as aliasing, and is not permitted in OpenGL
> +	     *     ES Shading Language 3.00 vertex shaders. LinkProgram will
> +	     *     fail when this condition exists. However, aliasing is
> +	     *     possible in OpenGL ES Shading Language 1.00 vertex shaders.
> +	     *     This will only work if only one of the aliased attributes
> +	     *     is active in the executable program, or if no path through
> +	     *     the shader consumes more than one attribute of a set of
> +	     *     attributes aliased to the same location. A link error can
> +	     *     occur if the linker determines that every path through the
> +	     *     shader consumes multiple aliased attributes, but implemen-
> +	     *     tations are not required to generate an error in this case."
> +	     *
> +	     *     After looking at above references from OpenGL, OpenGL ES
> +	     *     and GLSL specifications, we allow aliasing of vertex input
> +	     *     variables in: OpenGL 2.0 (and above) and OpenGL ES 2.0.
> +	     *
> +	     *     NOTE: This is not required by the spec but its worth
> +	     *     mentioning here that we're not doing anything to make sure
> +	     *     that no path through the vertex shader executable accesses
> +	     *     multiple inputs assigned to any single location.

These last two paragraphis should be un-indented.

>  	     */
> +
>  	    /* Mask representing the contiguous slots that will be used by
>  	     * this attribute.
>  	     */
> @@ -1832,11 +1870,21 @@ assign_attribute_or_color_locations(gl_shader_program *prog,
>  	    if ((~(use_mask << attr) & used_locations) != used_locations) {
>  	       const char *const string = (target_index == MESA_SHADER_VERTEX)
>  		  ? "vertex shader input" : "fragment shader output";
> -	       linker_error(prog,
> -			    "insufficient contiguous locations "
> -			    "available for %s `%s' %d %d %d", string,
> -			    var->name, used_locations, use_mask, attr);
> -	       return false;
> +
> +               if (target_index == MESA_SHADER_FRAGMENT ||
> +                   (prog->IsES && prog->Version >= 300)) {
> +
> +                  linker_error(prog,
> +                               "overlapping location is assigned "
> +                               "to %s `%s' %d %d %d\n", string,
> +                               var->name, used_locations, use_mask, attr);
> +                  return false;
> +               } else {
> +                  linker_warning(prog,
> +                                 "overlapping location is assigned "
> +                                 "to %s `%s' %d %d %d\n", string,
> +                                 var->name, used_locations, use_mask, attr);
> +               }
>  	    }
>  
>  	    used_locations |= (use_mask << attr);



More information about the mesa-dev mailing list