On 8 September 2011 23:32, Eric Anholt <span dir="ltr">&lt;<a href="mailto:eric@anholt.net">eric@anholt.net</a>&gt;</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;">
Fixes piglit vertex-program-two-side back.<br>
---<br>
 src/mesa/drivers/dri/i965/gen6_sf_state.c |    9 +++++++++<br>
 1 files changed, 9 insertions(+), 0 deletions(-)<br>
<br>
diff --git a/src/mesa/drivers/dri/i965/gen6_sf_state.c b/src/mesa/drivers/dri/i965/gen6_sf_state.c<br>
index bb8bc83..4482e9c 100644<br>
--- a/src/mesa/drivers/dri/i965/gen6_sf_state.c<br>
+++ b/src/mesa/drivers/dri/i965/gen6_sf_state.c<br>
@@ -67,6 +67,15 @@ get_attr_override(struct brw_vue_map *vue_map, int urb_entry_read_offset,<br>
<br>
    /* Find the VUE slot for this attribute. */<br>
    slot = vue_map-&gt;vert_result_to_slot[vs_attr];<br>
+<br>
+   /* If there was only a back color written but not front, use back<br>
+    * as the color instead of undefined<br>
+    */<br>
+   if (slot == -1 &amp;&amp; vs_attr == VERT_RESULT_COL0)<br>
+      slot = vue_map-&gt;vert_result_to_slot[VERT_RESULT_BFC0];<br>
+   if (slot == -1 &amp;&amp; vs_attr == VERT_RESULT_COL1)<br>
+      slot = vue_map-&gt;vert_result_to_slot[VERT_RESULT_BFC1];<br>
+<br>
    if (slot == -1) {<br>
       /* This attribute does not exist in the VUE--that means that the vertex<br>
        * shader did not write to it.  Behavior is undefined in this case, so<br>
<font color="#888888">--<br>
1.7.5.4<br>
<br>
_______________________________________________<br>
mesa-dev mailing list<br>
<a href="mailto:mesa-dev@lists.freedesktop.org">mesa-dev@lists.freedesktop.org</a><br>
<a href="http://lists.freedesktop.org/mailman/listinfo/mesa-dev" target="_blank">http://lists.freedesktop.org/mailman/listinfo/mesa-dev</a><br>
</font></blockquote></div><br>For Gen4 and Gen5, I believe that analogous logic has to be added to added to brw_sf_emit.c.<br>