[Mesa-dev] [PATCH 01/11] mesa: Add support for glGetProgramiv pnames for UBOs.

Brian Paul brianp at vmware.com
Fri Jul 20 15:44:24 PDT 2012


On 07/20/2012 04:33 PM, Eric Anholt wrote:
> Fixes piglit ARB_uniform_buffer_object/getprogramiv.
> ---
>   src/mesa/main/shaderapi.c |   19 +++++++++++++++++++
>   1 file changed, 19 insertions(+)
>
> diff --git a/src/mesa/main/shaderapi.c b/src/mesa/main/shaderapi.c
> index 6927368..f381915 100644
> --- a/src/mesa/main/shaderapi.c
> +++ b/src/mesa/main/shaderapi.c
> @@ -542,6 +542,25 @@ get_programiv(struct gl_context *ctx, GLuint program, GLenum pname, GLint *param
>         *params = shProg->Geom.OutputType;
>         break;
>   #endif
> +   case GL_ACTIVE_UNIFORM_BLOCK_MAX_NAME_LENGTH: {
> +      unsigned i;
> +      GLint max_len = 0;
> +
> +      for (i = 0; i<  shProg->NumUniformBlocks; i++) {
> +	 /* Add one for the terminating NUL character.
> +	  */
> +	 const GLint len = strlen(shProg->UniformBlocks[i].Name) + 1;
> +
> +	 if (len>  max_len)
> +	    max_len = len;
> +      }
> +
> +      *params = max_len;
> +      break;
> +   }
> +   case GL_ACTIVE_UNIFORM_BLOCKS:
> +      *params = shProg->NumUniformBlocks;
> +      break;
>      default:
>         _mesa_error(ctx, GL_INVALID_ENUM, "glGetProgramiv(pname)");
>         return;

It looks like these new cases (and the existing cases for geometry 
shaders and transform feedback) need extension tests:

if (!ctx->Extensions.ARB_uniform_buffer_object) {
    _mesa_error(ctx, GL_INVALID_ENUM, "glGetProgramiv");
    return;
}

Since there would be a quite a few of these, a goto-error handler at 
the end of the function would be good.

-Brian


More information about the mesa-dev mailing list