From: Samuel Pitoiset Date: Mon, 26 Jun 2017 13:31:28 +0000 (+0200) Subject: mesa: add shader_storage_block_binding() helper X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=edd50828618ed2efe799013c2723d67c407d86b4;p=mesa.git mesa: add shader_storage_block_binding() helper Signed-off-by: Samuel Pitoiset Reviewed-by: Timothy Arceri --- diff --git a/src/mesa/main/uniforms.c b/src/mesa/main/uniforms.c index a71e0695b05..28f530c4f68 100644 --- a/src/mesa/main/uniforms.c +++ b/src/mesa/main/uniforms.c @@ -1145,6 +1145,23 @@ _mesa_UniformBlockBinding(GLuint program, uniform_block_binding(ctx, shProg, uniformBlockIndex, uniformBlockBinding); } +static void +shader_storage_block_binding(struct gl_context *ctx, + struct gl_shader_program *shProg, + GLuint shaderStorageBlockIndex, + GLuint shaderStorageBlockBinding) +{ + if (shProg->data->ShaderStorageBlocks[shaderStorageBlockIndex].Binding != + shaderStorageBlockBinding) { + + FLUSH_VERTICES(ctx, 0); + ctx->NewDriverState |= ctx->DriverFlags.NewShaderStorageBuffer; + + shProg->data->ShaderStorageBlocks[shaderStorageBlockIndex].Binding = + shaderStorageBlockBinding; + } +} + void GLAPIENTRY _mesa_ShaderStorageBlockBinding(GLuint program, GLuint shaderStorageBlockIndex, @@ -1179,15 +1196,8 @@ _mesa_ShaderStorageBlockBinding(GLuint program, return; } - if (shProg->data->ShaderStorageBlocks[shaderStorageBlockIndex].Binding != - shaderStorageBlockBinding) { - - FLUSH_VERTICES(ctx, 0); - ctx->NewDriverState |= ctx->DriverFlags.NewShaderStorageBuffer; - - shProg->data->ShaderStorageBlocks[shaderStorageBlockIndex].Binding = - shaderStorageBlockBinding; - } + shader_storage_block_binding(ctx, shProg, shaderStorageBlockIndex, + shaderStorageBlockBinding); } /**