From: Iago Toral Quiroga Date: Wed, 19 Jun 2019 08:28:12 +0000 (+0200) Subject: v3d: flush jobs writing to vertex buffers used in the current draw call X-Git-Tag: upstream/19.3.0~5238 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=4d8f82946b22396c90ca102a44de7bdebd8838d6;p=platform%2Fupstream%2Fmesa.git v3d: flush jobs writing to vertex buffers used in the current draw call This can happen when any of our vertex buffers was written by a previous transform feedback draw. Fixes the following piglit tests: spec/ext_transform_feedback/position-render-bufferbase spec/ext_transform_feedback/position-render-bufferbase-discard spec/ext_transform_feedback/position-render-bufferoffset spec/ext_transform_feedback/position-render-bufferoffset-discard spec/ext_transform_feedback/position-render-bufferrange spec/ext_transform_feedback/position-render-bufferrange-discard Reviewed-by: Eric Anholt --- diff --git a/src/gallium/drivers/v3d/v3dx_draw.c b/src/gallium/drivers/v3d/v3dx_draw.c index 98f6307..fe07231 100644 --- a/src/gallium/drivers/v3d/v3dx_draw.c +++ b/src/gallium/drivers/v3d/v3dx_draw.c @@ -177,6 +177,15 @@ v3d_predraw_check_stage_inputs(struct pipe_context *pctx, v3d_flush_jobs_writing_resource(v3d, view->base.resource); } + + /* Flush writes to our vertex buffers (i.e. from transform feedback) */ + if (s == PIPE_SHADER_VERTEX) { + foreach_bit(i, v3d->vertexbuf.enabled_mask) { + struct pipe_vertex_buffer *vb = &v3d->vertexbuf.vb[i]; + + v3d_flush_jobs_writing_resource(v3d, vb->buffer.resource); + } + } } static void