[Mesa-dev] [PATCH] mesa: implement AMD_shader_stencil_export

Ian Romanick idr at freedesktop.org
Mon May 2 11:20:43 PDT 2011


-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1

On 05/02/2011 08:50 AM, Marek Olšák wrote:
> It's just an alias of the ARB variant with some GLSL compiler changes.

Other than the test suggestion (below) and Brian's comment about the
stand-alone compiler:

Reviewed-by: Ian Romanick <ian.d.romanick at intel.com>

> ---
>  src/glsl/glsl_parser_extras.cpp |   10 ++++++++++
>  src/glsl/glsl_parser_extras.h   |    2 ++
>  src/glsl/ir_variable.cpp        |   20 ++++++++++++++++++++
>  src/mesa/main/extensions.c      |    1 +
>  4 files changed, 33 insertions(+), 0 deletions(-)
> 
> diff --git a/src/glsl/glsl_parser_extras.cpp b/src/glsl/glsl_parser_extras.cpp
> index 5bb3a6f..18bff88 100644
> --- a/src/glsl/glsl_parser_extras.cpp
> +++ b/src/glsl/glsl_parser_extras.cpp
> @@ -255,6 +255,16 @@ _mesa_glsl_process_extension(const char *name, YYLTYPE *name_locp,
>        state->AMD_conservative_depth_enable = (ext_mode != extension_disable);
>        state->AMD_conservative_depth_warn = (ext_mode == extension_warn);
>        unsupported = !state->extensions->AMD_conservative_depth;
> +   } else if (strcmp(name, "GL_AMD_shader_stencil_export") == 0) {
> +      state->AMD_shader_stencil_export_enable = (ext_mode != extension_disable);
> +      state->AMD_shader_stencil_export_warn = (ext_mode == extension_warn);
> +
> +      /* This extension is only supported in fragment shaders.
> +       * Both the ARB and AMD variants share the same ARB flag
> +       * in gl_extensions.
> +       */
> +      unsupported = (state->target != fragment_shader)
> +	 || !state->extensions->ARB_shader_stencil_export;

I think it's worth adding piglit tests that enabling one extension
doesn't make the variables from the other magically appear.

#extension GL_AMD_shader_stencil_export: require
void main() { gl_FragStencilRefARB = 0; }

and

#extension GL_ARB_shader_stencil_export: require
void main() { gl_FragStencilRefAMD = 0; }

I have a sinking feeling that AMD may enable both variables if the AMD
extension is enabled.

>     } else if (strcmp(name, "GL_OES_texture_3D") == 0 && state->es_shader) {
>        state->OES_texture_3D_enable = (ext_mode != extension_disable);
>        state->OES_texture_3D_warn = (ext_mode == extension_warn);
> diff --git a/src/glsl/glsl_parser_extras.h b/src/glsl/glsl_parser_extras.h
> index 6df0e16..f914765 100644
> --- a/src/glsl/glsl_parser_extras.h
> +++ b/src/glsl/glsl_parser_extras.h
> @@ -172,6 +172,8 @@ struct _mesa_glsl_parse_state {
>     unsigned ARB_shader_stencil_export_warn:1;
>     unsigned AMD_conservative_depth_enable:1;
>     unsigned AMD_conservative_depth_warn:1;
> +   unsigned AMD_shader_stencil_export_enable:1;
> +   unsigned AMD_shader_stencil_export_warn:1;
>     unsigned OES_texture_3D_enable:1;
>     unsigned OES_texture_3D_warn:1;
>     /*@}*/
> diff --git a/src/glsl/ir_variable.cpp b/src/glsl/ir_variable.cpp
> index f357717..b848769 100644
> --- a/src/glsl/ir_variable.cpp
> +++ b/src/glsl/ir_variable.cpp
> @@ -767,6 +767,22 @@ generate_ARB_shader_stencil_export_variables(exec_list *instructions,
>  }
>  
>  static void
> +generate_AMD_shader_stencil_export_variables(exec_list *instructions,
> +					     struct _mesa_glsl_parse_state *state,
> +					     bool warn)
> +{
> +   /* gl_FragStencilRefAMD is only available in the fragment shader.
> +    */
> +   ir_variable *const fd =
> +      add_variable(instructions, state->symbols,
> +		   "gl_FragStencilRefAMD", glsl_type::int_type,
> +		   ir_var_out, FRAG_RESULT_STENCIL);
> +
> +   if (warn)
> +      fd->warn_extension = "GL_AMD_shader_stencil_export";
> +}
> +
> +static void
>  generate_120_fs_variables(exec_list *instructions,
>  			  struct _mesa_glsl_parse_state *state)
>  {
> @@ -818,6 +834,10 @@ initialize_fs_variables(exec_list *instructions,
>     if (state->ARB_shader_stencil_export_enable)
>        generate_ARB_shader_stencil_export_variables(instructions, state,
>  						   state->ARB_shader_stencil_export_warn);
> +
> +   if (state->AMD_shader_stencil_export_enable)
> +      generate_AMD_shader_stencil_export_variables(instructions, state,
> +						   state->AMD_shader_stencil_export_warn);
>  }
>  
>  void
> diff --git a/src/mesa/main/extensions.c b/src/mesa/main/extensions.c
> index beec70a..1062cde 100644
> --- a/src/mesa/main/extensions.c
> +++ b/src/mesa/main/extensions.c
> @@ -260,6 +260,7 @@ static const struct extension extension_table[] = {
>     { "GL_3DFX_texture_compression_FXT1",           o(TDFX_texture_compression_FXT1),           GL,             1999 },
>     { "GL_AMD_conservative_depth",                  o(AMD_conservative_depth),                  GL,             2009 },
>     { "GL_AMD_draw_buffers_blend",                  o(ARB_draw_buffers_blend),                  GL,             2009 },
> +   { "GL_AMD_shader_stencil_export",               o(ARB_shader_stencil_export),               GL,             2009 },
>     { "GL_APPLE_client_storage",                    o(APPLE_client_storage),                    GL,             2002 },
>     { "GL_APPLE_object_purgeable",                  o(APPLE_object_purgeable),                  GL,             2006 },
>     { "GL_APPLE_packed_pixels",                     o(APPLE_packed_pixels),                     GL,             2002 },
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.11 (GNU/Linux)
Comment: Using GnuPG with Fedora - http://enigmail.mozdev.org/

iEYEARECAAYFAk2+9foACgkQX1gOwKyEAw+KeACeNLY2Cj8rtgfr3/tfdXWj84rR
cRIAnR3r3d6iwcX7woy1DZzXthV+tYyu
=/KLI
-----END PGP SIGNATURE-----


More information about the mesa-dev mailing list