From: Eric Anholt Date: Fri, 23 Mar 2018 22:43:50 +0000 (-0700) Subject: broadcom/vc5: Disable TF on V3D 4.x when drawing with queries disabled. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=262208eb3c2c53a1fd807bc76b12088f6ce2c56d;p=mesa.git broadcom/vc5: Disable TF on V3D 4.x when drawing with queries disabled. On 3.x, we just don't flag the primitive as needing TF, but those primitive bits are now allocated to the new primitive types. Now we need to actually update the enable flag at draw time. --- diff --git a/src/gallium/drivers/vc5/vc5_emit.c b/src/gallium/drivers/vc5/vc5_emit.c index a98fd037d08..d5bf2824d29 100644 --- a/src/gallium/drivers/vc5/vc5_emit.c +++ b/src/gallium/drivers/vc5/vc5_emit.c @@ -604,6 +604,13 @@ v3dX(emit_state)(struct pipe_context *pctx) for (int i = 0; i < vc5->prog.bind_vs->num_tf_specs; i++) { cl_emit_prepacked(&job->bcl, &tf_specs[i]); } + } else if (job->tf_enabled) { +#if V3D_VERSION >= 40 + cl_emit(&job->bcl, TRANSFORM_FEEDBACK_SPECS, tfe) { + tfe.enable = false; + }; + job->tf_enabled = false; +#endif /* V3D_VERSION >= 40 */ } } diff --git a/src/gallium/drivers/vc5/vc5_query.c b/src/gallium/drivers/vc5/vc5_query.c index 5ec9be2e356..9aa80cf536a 100644 --- a/src/gallium/drivers/vc5/vc5_query.c +++ b/src/gallium/drivers/vc5/vc5_query.c @@ -164,6 +164,7 @@ vc5_set_active_query_state(struct pipe_context *pctx, boolean enable) vc5->active_queries = enable; vc5->dirty |= VC5_DIRTY_OQ; + vc5->dirty |= VC5_DIRTY_STREAMOUT; } void