Commit a7fa44cd authored by Rob Clark's avatar Rob Clark 💬

freedreno: fix FD_MESA_DEBUG=flush

The logic to force a flush every draw was short-circuited with newer
kernels.  Also it should apply to clears as well.
Signed-off-by: Rob Clark's avatarRob Clark <robdclark@gmail.com>
parent 83c5c026
......@@ -483,12 +483,16 @@ fd_batch_check_size(struct fd_batch *batch)
{
debug_assert(!batch->flushed);
if (unlikely(fd_mesa_debug & FD_DBG_FLUSH)) {
fd_batch_flush(batch, true, false);
return;
}
if (fd_device_version(batch->ctx->screen->dev) >= FD_VERSION_UNLIMITED_CMDS)
return;
struct fd_ringbuffer *ring = batch->draw;
if (((ring->cur - ring->start) > (ring->size/4 - 0x1000)) ||
(fd_mesa_debug & FD_DBG_FLUSH))
if ((ring->cur - ring->start) > (ring->size/4 - 0x1000))
fd_batch_flush(batch, true, false);
}
......
......@@ -429,6 +429,8 @@ fd_clear(struct pipe_context *pctx, unsigned buffers,
if (fallback) {
fd_blitter_clear(pctx, buffers, color, depth, stencil);
}
fd_batch_check_size(batch);
}
static void
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment