diff --git a/.pick_status.json b/.pick_status.json index 113226ce72b..8be92a3e489 100644 --- a/.pick_status.json +++ b/.pick_status.json @@ -1219,7 +1219,7 @@ "description": "zink: flag vertex buffers for rebind after vstate draws", "nominated": true, "nomination_type": 0, - "resolution": 0, + "resolution": 1, "main_sha": null, "because_sha": null }, diff --git a/src/gallium/drivers/zink/zink_draw.cpp b/src/gallium/drivers/zink/zink_draw.cpp index d8c24e785c4..7f2196f42a9 100644 --- a/src/gallium/drivers/zink/zink_draw.cpp +++ b/src/gallium/drivers/zink/zink_draw.cpp @@ -974,6 +974,8 @@ zink_draw_vertex_state(struct pipe_context *pctx, ctx->gfx_pipeline_state.element_state = &((struct zink_vertex_state*)vstate)->velems.hw_state; zink_draw(pctx, &dinfo, 0, NULL, draws, num_draws, vstate, partial_velem_mask); + /* ensure ctx->vertex_buffers gets rebound on next non-vstate draw */ + ctx->vertex_buffers_dirty = true; ctx->gfx_pipeline_state.element_state = hw_state; if (info.take_vertex_state_ownership)