Module: Mesa
Branch: master
Commit: 116811e9639903227242db753e2931428cc0a962
URL:    
http://cgit.freedesktop.org/mesa/mesa/commit/?id=116811e9639903227242db753e2931428cc0a962

Author: Mike Blumenkrantz <[email protected]>
Date:   Wed Nov  4 09:08:14 2020 -0500

zink: trigger pending clears during flush

this applies all pending fb clears at the time of flush to handle the scenario
of start -> clear() -> flush() properly

Reviewed-by: Dave Airlie <[email protected]>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/9726>

---

 src/gallium/drivers/zink/zink_context.c | 5 +++++
 1 file changed, 5 insertions(+)

diff --git a/src/gallium/drivers/zink/zink_context.c 
b/src/gallium/drivers/zink/zink_context.c
index f12f4df7830..c19c45d9484 100644
--- a/src/gallium/drivers/zink/zink_context.c
+++ b/src/gallium/drivers/zink/zink_context.c
@@ -1783,6 +1783,11 @@ zink_flush(struct pipe_context *pctx,
    struct zink_batch *batch = zink_batch_g(ctx);
    struct zink_fence *fence = &batch->state->fence;
 
+   if (!deferred && ctx->clears_enabled) {
+      /* start rp to do all the clears */
+      zink_begin_render_pass(ctx, batch);
+   }
+
    if (deferred)
       batch->state->fence.deferred_ctx = pctx;
    else if (batch->has_work) {

_______________________________________________
mesa-commit mailing list
[email protected]
https://lists.freedesktop.org/mailman/listinfo/mesa-commit

Reply via email to