[Mesa-dev] [PATCH 5/7] mesa: check for no state change in VertexAttribDivisor()

Jose Fonseca jfonseca at vmware.com
Tue Feb 28 03:01:56 PST 2012


Looks good to me.

Jose

----- Original Message -----
> From: Brian Paul <brianp at vmware.com>
> 
> ---
>  src/mesa/main/varray.c |   10 ++++++++--
>  1 files changed, 8 insertions(+), 2 deletions(-)
> 
> diff --git a/src/mesa/main/varray.c b/src/mesa/main/varray.c
> index 39d3a27..a402c7b 100644
> --- a/src/mesa/main/varray.c
> +++ b/src/mesa/main/varray.c
> @@ -1117,8 +1117,9 @@ _mesa_PrimitiveRestartIndex(GLuint index)
>  void GLAPIENTRY
>  _mesa_VertexAttribDivisor(GLuint index, GLuint divisor)
>  {
> +   struct gl_client_array *array;
>     GET_CURRENT_CONTEXT(ctx);
> -   ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx);
> +   ASSERT_OUTSIDE_BEGIN_END(ctx);
>  
>     if (!ctx->Extensions.ARB_instanced_arrays) {
>        _mesa_error(ctx, GL_INVALID_OPERATION,
>        "glVertexAttribDivisor()");
> @@ -1133,7 +1134,12 @@ _mesa_VertexAttribDivisor(GLuint index, GLuint
> divisor)
>  
>     ASSERT(VERT_ATTRIB_GENERIC(index) <
>     Elements(ctx->Array.ArrayObj->VertexAttrib));
>  
> -
>   ctx->Array.ArrayObj->VertexAttrib[VERT_ATTRIB_GENERIC(index)].InstanceDivisor
> = divisor;
> +   array =
> &ctx->Array.ArrayObj->VertexAttrib[VERT_ATTRIB_GENERIC(index)];
> +   if (array->InstanceDivisor != divisor) {
> +      FLUSH_VERTICES(ctx, _NEW_ARRAY);
> +      array->InstanceDivisor = divisor;
> +      ctx->Array.NewState |= VERT_BIT(VERT_ATTRIB_GENERIC(index));
> +   }
>  }
>  
>  
> --
> 1.7.1
> 
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/mesa-dev
> 


More information about the mesa-dev mailing list