[Mesa-dev] [PATCH] main/mesa: missing atomic buffer bindings to mesa are added in this patch

Matt Turner mattst88 at gmail.com
Thu Jul 24 13:14:37 PDT 2014


The commit message should be something like

"mesa: Add missing atomic buffer bindings and unbindings."

On Thu, Jul 24, 2014 at 12:18 PM, Aditya Atluri
<adityaavinash1 at gmail.com> wrote:
> ---
>  src/mesa/main/bufferobj.c |   31 +++++++++++++++++++++++++++++++
>  1 file changed, 31 insertions(+)
>
> diff --git a/src/mesa/main/bufferobj.c b/src/mesa/main/bufferobj.c
> index 7b1bba0..1dfcda3 100644
> --- a/src/mesa/main/bufferobj.c
> +++ b/src/mesa/main/bufferobj.c
> @@ -832,6 +832,9 @@ _mesa_init_buffer_objects( struct gl_context *ctx )
>     _mesa_reference_buffer_object(ctx, &ctx->UniformBuffer,
>                                  ctx->Shared->NullBufferObj);
>
> +   _mesa_reference_buffer_object(ctx, &ctx->AtomicBuffer,
> +                                ctx->Shared->NullBufferObj);
> +
>     _mesa_reference_buffer_object(ctx, &ctx->DrawIndirectBuffer,
>                                  ctx->Shared->NullBufferObj);
>
> @@ -842,6 +845,14 @@ _mesa_init_buffer_objects( struct gl_context *ctx )
>        ctx->UniformBufferBindings[i].Offset = -1;
>        ctx->UniformBufferBindings[i].Size = -1;
>     }
> +
> +   for (i = 0; i < MAX_COMBINED_ATOMIC_BUFFERS; i++) {
> +      _mesa_reference_buffer_object(ctx,
> +                                   &ctx->AtomicBufferBindings[i].BufferObject,
> +                                   ctx->Shared->NullBufferObj);
> +      ctx->AtomicBufferBindings[i].Offset = -1;
> +      ctx->AtomicBufferBindings[i].Size = -1;
> +   }
>  }
>
>
> @@ -857,6 +868,8 @@ _mesa_free_buffer_objects( struct gl_context *ctx )
>
>     _mesa_reference_buffer_object(ctx, &ctx->UniformBuffer, NULL);
>
> +   _mesa_reference_buffer_object(ctx, &ctx->AtomicBuffer, NULL);
> +
>     _mesa_reference_buffer_object(ctx, &ctx->DrawIndirectBuffer, NULL);
>
>     for (i = 0; i < MAX_COMBINED_UNIFORM_BUFFERS; i++) {
> @@ -864,6 +877,13 @@ _mesa_free_buffer_objects( struct gl_context *ctx )
>                                     &ctx->UniformBufferBindings[i].BufferObject,
>                                     NULL);
>     }
> +
> +   for (i = 0; i < MAX_COMBINED_ATOMIC_BUFFERS; i++) {
> +      _mesa_reference_buffer_object(ctx,
> +                                   &ctx->AtomicBufferBindings[i].BufferObject,
> +                                   NULL);
> +   }
> +
>  }
>
>  bool
> @@ -1200,6 +1220,17 @@ _mesa_DeleteBuffers(GLsizei n, const GLuint *ids)
>              _mesa_BindBuffer( GL_UNIFORM_BUFFER, 0 );
>           }
>
> +         /* unbind Atomci Buffer binding points */

Atomic


More information about the mesa-dev mailing list