summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/mesa/drivers/dri/i965/gen6_clip_state.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/src/mesa/drivers/dri/i965/gen6_clip_state.c b/src/mesa/drivers/dri/i965/gen6_clip_state.c
index 5ba3a807603..8ae19c8d370 100644
--- a/src/mesa/drivers/dri/i965/gen6_clip_state.c
+++ b/src/mesa/drivers/dri/i965/gen6_clip_state.c
@@ -177,6 +177,11 @@ upload_clip_state(struct brw_context *brw)
if (!is_drawing_points(brw) && !is_drawing_lines(brw))
dw2 |= GEN6_CLIP_XY_TEST;
+ /* BRW_NEW_VUE_MAP_GEOM_OUT */
+ const int max_vp_index =
+ (brw->vue_map_geom_out.slots_valid & VARYING_BIT_VIEWPORT) != 0 ?
+ ctx->Const.MaxViewports : 1;
+
BEGIN_BATCH(4);
OUT_BATCH(_3DSTATE_CLIP << 16 | (4 - 2));
OUT_BATCH(dw1);
@@ -186,7 +191,7 @@ upload_clip_state(struct brw_context *brw)
OUT_BATCH(U_FIXED(0.125, 3) << GEN6_CLIP_MIN_POINT_WIDTH_SHIFT |
U_FIXED(255.875, 3) << GEN6_CLIP_MAX_POINT_WIDTH_SHIFT |
(_mesa_geometric_layers(fb) > 0 ? 0 : GEN6_CLIP_FORCE_ZERO_RTAINDEX) |
- ((ctx->Const.MaxViewports - 1) & GEN6_CLIP_MAX_VP_INDEX_MASK));
+ ((max_vp_index - 1) & GEN6_CLIP_MAX_VP_INDEX_MASK));
ADVANCE_BATCH();
}
@@ -201,7 +206,8 @@ const struct brw_tracked_state gen6_clip_state = {
BRW_NEW_GEOMETRY_PROGRAM |
BRW_NEW_META_IN_PROGRESS |
BRW_NEW_PRIMITIVE |
- BRW_NEW_RASTERIZER_DISCARD,
+ BRW_NEW_RASTERIZER_DISCARD |
+ BRW_NEW_VUE_MAP_GEOM_OUT,
},
.emit = upload_clip_state,
};
@@ -218,7 +224,8 @@ const struct brw_tracked_state gen7_clip_state = {
BRW_NEW_GEOMETRY_PROGRAM |
BRW_NEW_META_IN_PROGRESS |
BRW_NEW_PRIMITIVE |
- BRW_NEW_RASTERIZER_DISCARD,
+ BRW_NEW_RASTERIZER_DISCARD |
+ BRW_NEW_VUE_MAP_GEOM_OUT,
},
.emit = upload_clip_state,
};