On 2 September 2011 11:59, Eric Anholt <span dir="ltr"><<a href="mailto:eric@anholt.net">eric@anholt.net</a>></span> wrote:<br><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
<div><div></div><div class="h5">On Fri, 2 Sep 2011 09:06:40 -0700, Paul Berry <<a href="mailto:stereotype441@gmail.com">stereotype441@gmail.com</a>> wrote:<br>
> Previously, this conversion was duplicated in several places in the<br>
> i965 driver. This patch moves it to a common location in mtypes.h,<br>
> near the declaration of gl_vert_result and gl_frag_attrib.<br>
><br>
> I've also added comments to remind us that we may need to revisit the<br>
> conversion code when adding elements to gl_vert_result and<br>
> gl_frag_attrib.<br>
> ---<br>
> src/gallium/drivers/i965/brw_wm_glsl.c | 9 +-----<br>
> src/mesa/drivers/dri/i965/brw_fs.cpp | 16 +--------<br>
> src/mesa/drivers/dri/i965/brw_vs_constval.c | 8 +---<br>
> src/mesa/drivers/dri/i965/brw_wm_pass2.c | 9 +-----<br>
> src/mesa/drivers/dri/i965/gen6_sf_state.c | 15 ++------<br>
> src/mesa/main/mtypes.h | 45 +++++++++++++++++++++++++-<br>
> 6 files changed, 53 insertions(+), 49 deletions(-)<br>
><br>
> diff --git a/src/gallium/drivers/i965/brw_wm_glsl.c b/src/gallium/drivers/i965/brw_wm_glsl.c<br>
> index fb8e40d..9efb003 100644<br>
> --- a/src/gallium/drivers/i965/brw_wm_glsl.c<br>
> +++ b/src/gallium/drivers/i965/brw_wm_glsl.c<br>
> @@ -388,14 +388,7 @@ static void prealloc_reg(struct brw_wm_compile *c)<br>
><br>
> /* fragment shader inputs */<br>
> for (i = 0; i < VERT_RESULT_MAX; i++) {<br>
> - int fp_input;<br>
> -<br>
> - if (i >= VERT_RESULT_VAR0)<br>
> - fp_input = i - VERT_RESULT_VAR0 + FRAG_ATTRIB_VAR0;<br>
> - else if (i <= VERT_RESULT_TEX7)<br>
> - fp_input = i;<br>
> - else<br>
> - fp_input = -1;<br>
> + int fp_input = vert_result_to_frag_attrib(i);<br>
><br>
> if (fp_input >= 0 && inputs & (1 << fp_input)) {<br>
> urb_read_length = reg_index;<br>
<br>
</div></div>Probably don't want to be touching this code.<br>
<div><div></div><div class="h5"><br>
> diff --git a/src/mesa/main/mtypes.h b/src/mesa/main/mtypes.h<br>
> index 44ebf0a..776872c 100644<br>
> --- a/src/mesa/main/mtypes.h<br>
> +++ b/src/mesa/main/mtypes.h<br>
> @@ -215,7 +215,9 @@ typedef enum<br>
><br>
><br>
> /**<br>
> - * Indexes for vertex program result attributes<br>
> + * Indexes for vertex program result attributes. Note that<br>
> + * vert_result_to_frag_attrib() and frag_attrib_to_vert_result() make<br>
> + * assumptions about the layout of this enum.<br>
> */<br>
> typedef enum<br>
> {<br>
> @@ -313,7 +315,9 @@ typedef enum<br>
><br>
><br>
> /**<br>
> - * Indexes for fragment program input attributes.<br>
> + * Indexes for fragment program input attributes. Note that<br>
> + * vert_result_to_frag_attrib() and frag_attrib_to_vert_result() make<br>
> + * assumptions about the layout of this enum.<br>
> */<br>
> typedef enum<br>
> {<br>
> @@ -336,6 +340,43 @@ typedef enum<br>
> } gl_frag_attrib;<br>
><br>
> /**<br>
> + * Convert from a gl_vert_result value to the corresponding gl_frag_attrib.<br>
> + *<br>
> + * VERT_RESULT_HPOS is converted to FRAG_ATTRIB_WPOS.<br>
> + *<br>
> + * gl_vert_result values which have no corresponding gl_frag_attrib<br>
> + * (VERT_RESULT_PSIZ, VERT_RESULT_BFC0, VERT_RESULT_BFC1, and<br>
> + * VERT_RESULT_EDGE) are converted to a value of -1.<br>
> + */<br>
> +static inline int vert_result_to_frag_attrib(int vert_result)<br>
> +{<br>
> + if (vert_result >= VERT_RESULT_VAR0)<br>
> + return vert_result - VERT_RESULT_VAR0 + FRAG_ATTRIB_VAR0;<br>
> + else if (vert_result <= VERT_RESULT_TEX7)<br>
> + return vert_result;<br>
> + else<br>
> + return -1;<br>
> +}<br>
> +<br>
> +/**<br>
> + * Convert from a gl_frag_attrib value to the corresponding gl_vert_result.<br>
> + *<br>
> + * FRAG_ATTRIB_WPOS is converted to VERT_RESULT_HPOS.<br>
> + *<br>
> + * gl_frag_attrib values which have no corresponding gl_vert_result<br>
> + * (FRAG_ATTRIB_FACE and FRAG_ATTRIB_PNTC) are converted to a value of -1.<br>
> + */<br>
> +static inline int frag_attrib_to_vert_result(int frag_attrib)<br>
> +{<br>
> + if (frag_attrib <= FRAG_ATTRIB_TEX7)<br>
> + return frag_attrib;<br>
> + else if (frag_attrib >= FRAG_ATTRIB_VAR0)<br>
> + return frag_attrib - FRAG_ATTRIB_VAR0 + VERT_RESULT_VAR0;<br>
> + else<br>
> + return -1;<br>
> +}<br>
> +<br>
> +/**<br>
> * Bitflags for fragment program input attributes.<br>
> */<br>
> /*@{*/<br>
<br>
</div></div>This looks to be the first inline functions in mtypes.h. I suspect the<br>
code should go somewhere else, but I don't know where.<br>
</blockquote></div><br>My reasoning for putting these functions in mtypes.h was that I wanted to put them as near as possible to the enums they were related to, especially since they will likely need updating when we modify those enums. I'm open to other suggestions about where to put them if anyone cares strongly.<br>