Mesa (master): freedreno/batch: Cleanup submit immediately after flush

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Tue Nov 10 18:27:28 UTC 2020


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

Author: Rob Clark <robdclark at chromium.org>
Date:   Thu Oct 29 15:28:11 2020 -0700

freedreno/batch: Cleanup submit immediately after flush

No reason to keep these around if the batch is not immediately unref'd.

Signed-off-by: Rob Clark <robdclark at chromium.org>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/7342>

---

 src/gallium/drivers/freedreno/freedreno_batch.c | 35 ++++++++++++++++---------
 1 file changed, 23 insertions(+), 12 deletions(-)

diff --git a/src/gallium/drivers/freedreno/freedreno_batch.c b/src/gallium/drivers/freedreno/freedreno_batch.c
index d9017b5c73a..ccef2d40c8d 100644
--- a/src/gallium/drivers/freedreno/freedreno_batch.c
+++ b/src/gallium/drivers/freedreno/freedreno_batch.c
@@ -143,19 +143,10 @@ fd_batch_create(struct fd_context *ctx, bool nondraw)
 }
 
 static void
-batch_fini(struct fd_batch *batch)
+cleanup_submit(struct fd_batch *batch)
 {
-	DBG("%p", batch);
-
-	pipe_resource_reference(&batch->query_buf, NULL);
-
-	if (batch->in_fence_fd != -1)
-		close(batch->in_fence_fd);
-
-	/* in case batch wasn't flushed but fence was created: */
-	fd_fence_populate(batch->fence, 0, -1);
-
-	fd_fence_ref(&batch->fence, NULL);
+	if (!batch->submit)
+		return;
 
 	fd_ringbuffer_del(batch->draw);
 	fd_ringbuffer_del(batch->gmem);
@@ -192,6 +183,25 @@ batch_fini(struct fd_batch *batch)
 	}
 
 	fd_submit_del(batch->submit);
+	batch->submit = NULL;
+}
+
+static void
+batch_fini(struct fd_batch *batch)
+{
+	DBG("%p", batch);
+
+	pipe_resource_reference(&batch->query_buf, NULL);
+
+	if (batch->in_fence_fd != -1)
+		close(batch->in_fence_fd);
+
+	/* in case batch wasn't flushed but fence was created: */
+	fd_fence_populate(batch->fence, 0, -1);
+
+	fd_fence_ref(&batch->fence, NULL);
+
+	cleanup_submit(batch);
 
 	util_dynarray_fini(&batch->draw_patches);
 	util_dynarray_fini(&batch->fb_read_patches);
@@ -355,6 +365,7 @@ batch_flush(struct fd_batch *batch)
 	 */
 	fd_bc_invalidate_batch(batch, false);
 	fd_screen_unlock(batch->ctx->screen);
+	cleanup_submit(batch);
 	fd_batch_unlock_submit(batch);
 }
 



More information about the mesa-commit mailing list