On 8 September 2011 23:32, 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;">
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->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 && vs_attr == VERT_RESULT_COL0)<br>
+ slot = vue_map->vert_result_to_slot[VERT_RESULT_BFC0];<br>
+ if (slot == -1 && vs_attr == VERT_RESULT_COL1)<br>
+ slot = vue_map->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>