[Mesa-dev] [PATCH 12/13] i965: If STATE_BASE_VERTEX is used, set its value
Ian Romanick
idr at freedesktop.org
Fri Jun 20 18:01:02 PDT 2014
From: Ian Romanick <ian.d.romanick at intel.com>
Signed-off-by: Ian Romanick <ian.d.romanick at intel.com>
Cc: "10.2" <mesa-stable at lists.freedesktop.org>
---
src/mesa/drivers/dri/i965/brw_draw.c | 37 ++++++++++++++++++++++++++++++++++++
1 file changed, 37 insertions(+)
diff --git a/src/mesa/drivers/dri/i965/brw_draw.c b/src/mesa/drivers/dri/i965/brw_draw.c
index ac21656..dd914b6 100644
--- a/src/mesa/drivers/dri/i965/brw_draw.c
+++ b/src/mesa/drivers/dri/i965/brw_draw.c
@@ -40,6 +40,7 @@
#include "swrast/swrast.h"
#include "swrast_setup/swrast_setup.h"
#include "drivers/common/meta.h"
+#include "program/prog_parameter.h"
#include "brw_blorp.h"
#include "brw_draw.h"
@@ -392,6 +393,27 @@ static bool brw_try_draw_prims( struct gl_context *ctx,
bool retval = true;
GLuint i;
bool fail_next = false;
+ GLint last_start = -1;
+ GLint base_vertex_idx = -1;
+
+ struct gl_program_parameter_list *const plist =
+ ctx->VertexProgram._Current->Base.Parameters;
+
+ /* Find the storage associated with STATE_BASE_VERTEX. If there is
+ * storage, then we'll need to update its value each time
+ * prims[i].basevertex changes.
+ */
+ for (unsigned j = 0; j < plist->NumParameters; j++) {
+ if (plist->Parameters[j].StateIndexes[0] == STATE_INTERNAL
+ && plist->Parameters[j].StateIndexes[1] == STATE_BASE_VERTEX) {
+ base_vertex_idx = j;
+ break;
+ }
+ }
+
+ if (base_vertex_idx >= 0) {
+ ctx->VertexProgram._Current->Base.Parameters->ParameterValues[base_vertex_idx][0].i = brw->basevertex;
+ }
if (ctx->NewState)
_mesa_update_state( ctx );
@@ -462,11 +484,26 @@ static bool brw_try_draw_prims( struct gl_context *ctx,
brw->basevertex != prims[i].basevertex) {
brw->num_instances = prims[i].num_instances;
brw->basevertex = prims[i].basevertex;
+
+ if (base_vertex_idx >= 0) {
+ plist->ParameterValues[base_vertex_idx][0].i = brw->basevertex;
+ ctx->NewState |= _NEW_PROGRAM_CONSTANTS;
+ _mesa_update_state(ctx);
+ }
+
if (i > 0) { /* For i == 0 we just did this before the loop */
brw->state.dirty.brw |= BRW_NEW_VERTICES;
brw_merge_inputs(brw, arrays);
}
}
+
+ if (prims[i].start != last_start && base_vertex_idx >= 0) {
+ plist->ParameterValues[base_vertex_idx][0].i = prims[i].start;
+ ctx->NewState |= _NEW_PROGRAM_CONSTANTS;
+ _mesa_update_state(ctx);
+ last_start = prims[i].start;
+ }
+
if (brw->gen < 6)
brw_set_prim(brw, &prims[i]);
else
--
1.8.1.4
More information about the mesa-dev
mailing list