[Mesa-dev] [PATCH 04/13] mesa: Group gl_system_value values by the stage where they exist
Roland Scheidegger
sroland at vmware.com
Sat Jun 21 08:19:20 PDT 2014
Am 21.06.2014 03:00, schrieb Ian Romanick:
> From: Ian Romanick <ian.d.romanick at intel.com>
>
> Signed-off-by: Ian Romanick <ian.d.romanick at intel.com>
> Cc: Ilia Mirkin <imirkin at alum.mit.edu>
> Cc: Marek Olšák <marek.olsak at amd.com>
> Cc: Roland Scheidegger <sroland at vmware.com>
> Cc: "10.2" <mesa-stable at lists.freedesktop.org>
> ---
> src/mesa/main/mtypes.h | 32 +++++++++++++++++++++++-------
> src/mesa/state_tracker/st_glsl_to_tgsi.cpp | 12 +++++++++--
> 2 files changed, 35 insertions(+), 9 deletions(-)
>
> diff --git a/src/mesa/main/mtypes.h b/src/mesa/main/mtypes.h
> index 8b7ee30..3899e7f 100644
> --- a/src/mesa/main/mtypes.h
> +++ b/src/mesa/main/mtypes.h
> @@ -2035,13 +2035,31 @@ typedef enum
> */
> typedef enum
> {
> - SYSTEM_VALUE_FRONT_FACE, /**< Fragment shader only (not done yet) */
> - SYSTEM_VALUE_VERTEX_ID, /**< Vertex shader only */
> - SYSTEM_VALUE_INSTANCE_ID, /**< Vertex shader only */
> - SYSTEM_VALUE_SAMPLE_ID, /**< Fragment shader only */
> - SYSTEM_VALUE_SAMPLE_POS, /**< Fragment shader only */
> - SYSTEM_VALUE_SAMPLE_MASK_IN, /**< Fragment shader only */
> - SYSTEM_VALUE_INVOCATION_ID, /**< Geometry shader only */
> + /**
> + * \name Vertex shader system values
> + */
> + /*@{*/
> + SYSTEM_VALUE_VERTEX_ID,
> + SYSTEM_VALUE_INSTANCE_ID,
> + /*@}*/
> +
> + /**
> + * \name Geometry shader system values
> + */
> + /*@{*/
> + SYSTEM_VALUE_INVOCATION_ID,
> + /*@}*/
> +
> + /**
> + * \name Fragment shader system values
> + */
> + /*@{*/
> + SYSTEM_VALUE_FRONT_FACE, /**< (not done yet) */
> + SYSTEM_VALUE_SAMPLE_ID,
> + SYSTEM_VALUE_SAMPLE_POS,
> + SYSTEM_VALUE_SAMPLE_MASK_IN,
> + /*@}*/
> +
> SYSTEM_VALUE_MAX /**< Number of values */
> } gl_system_value;
>
> diff --git a/src/mesa/state_tracker/st_glsl_to_tgsi.cpp b/src/mesa/state_tracker/st_glsl_to_tgsi.cpp
> index fbfbea6..fa95493 100644
> --- a/src/mesa/state_tracker/st_glsl_to_tgsi.cpp
> +++ b/src/mesa/state_tracker/st_glsl_to_tgsi.cpp
> @@ -4236,13 +4236,21 @@ struct st_translate {
>
> /** Map Mesa's SYSTEM_VALUE_x to TGSI_SEMANTIC_x */
> const unsigned _mesa_sysval_to_semantic[SYSTEM_VALUE_MAX] = {
> - TGSI_SEMANTIC_FACE,
> + /* Vertex shader
> + */
> TGSI_SEMANTIC_VERTEXID,
> TGSI_SEMANTIC_INSTANCEID,
> +
> + /* Geometry shader
> + */
> + TGSI_SEMANTIC_INVOCATIONID,
> +
> + /* Fragment shader
> + */
> + TGSI_SEMANTIC_FACE,
> TGSI_SEMANTIC_SAMPLEID,
> TGSI_SEMANTIC_SAMPLEPOS,
> TGSI_SEMANTIC_SAMPLEMASK,
> - TGSI_SEMANTIC_INVOCATIONID,
> };
>
> /**
>
Looks good to me (though it does mean you have to add new values in the
middle in the future if you group them by stage).
1-4 are
Reviewed-by: Roland Scheidegger <sroland at vmware.com>
More information about the mesa-dev
mailing list