From: Iago Toral Quiroga Date: Tue, 3 Jun 2014 10:25:08 +0000 (+0200) Subject: i965/gs: Set number of control data bits for stream mode. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=9650293b51b23b86f4fcf6875e1801555fa235d0;p=mesa.git i965/gs: Set number of control data bits for stream mode. If the geometry shader is indeed using streams then we need 2 control data bits per vertex for the StreamID. If the shader is not using streams then we don't need control data bits. Reviewed-by: Chris Forbes Reviewed-by: Ian Romanick --- diff --git a/src/mesa/drivers/dri/i965/brw_vec4_gs.c b/src/mesa/drivers/dri/i965/brw_vec4_gs.c index 4b1ba367341..64282916009 100644 --- a/src/mesa/drivers/dri/i965/brw_vec4_gs.c +++ b/src/mesa/drivers/dri/i965/brw_vec4_gs.c @@ -81,10 +81,11 @@ do_gs_prog(struct brw_context *brw, */ c.prog_data.control_data_format = GEN7_GS_CONTROL_DATA_FORMAT_GSCTL_SID; - /* However, StreamID is not yet supported, so we output zero bits of - * control data per vertex. - */ - c.control_data_bits_per_vertex = 0; + /* We only have to emit control bits if we are using streams */ + if (prog->Geom.UsesStreams) + c.control_data_bits_per_vertex = 2; + else + c.control_data_bits_per_vertex = 0; } else { /* When the output type is triangle_strip or line_strip, EndPrimitive() * may be used to terminate the current strip and start a new one