panfrost: Remove wait parameter to flush_all_batches

It is always false now.

Signed-off-by: Alyssa Rosenzweig <alyssa.rosenzweig@collabora.com>
Reviewed-by: Boris Brezillon <boris.brezillon@collabora.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/5995>
This commit is contained in:
Alyssa Rosenzweig 2020-07-20 11:48:16 -04:00 committed by Marge Bot
parent 0c4db886b6
commit e5ef5a381e
4 changed files with 6 additions and 36 deletions

View File

@ -135,7 +135,7 @@ panfrost_launch_grid(struct pipe_context *pipe,
panfrost_new_job(&batch->pool, &batch->scoreboard,
JOB_TYPE_COMPUTE, true, 0, &payload,
sizeof(payload), false);
panfrost_flush_all_batches(ctx, false);
panfrost_flush_all_batches(ctx);
}
static void

View File

@ -258,7 +258,7 @@ panfrost_flush(
}
/* Submit all pending jobs */
panfrost_flush_all_batches(ctx, false);
panfrost_flush_all_batches(ctx);
if (fence) {
struct panfrost_fence *f = panfrost_fence_create(ctx, &fences);
@ -279,7 +279,7 @@ static void
panfrost_texture_barrier(struct pipe_context *pipe, unsigned flags)
{
struct panfrost_context *ctx = pan_context(pipe);
panfrost_flush_all_batches(ctx, false);
panfrost_flush_all_batches(ctx);
}
#define DEFINE_CASE(c) case PIPE_PRIM_##c: return MALI_##c;
@ -1417,7 +1417,7 @@ panfrost_get_query_result(struct pipe_context *pipe,
case PIPE_QUERY_PRIMITIVES_GENERATED:
case PIPE_QUERY_PRIMITIVES_EMITTED:
panfrost_flush_all_batches(ctx, false);
panfrost_flush_all_batches(ctx);
vresult->u64 = query->end - query->start;
break;

View File

@ -1171,28 +1171,12 @@ out:
}
void
panfrost_flush_all_batches(struct panfrost_context *ctx, bool wait)
panfrost_flush_all_batches(struct panfrost_context *ctx)
{
struct util_dynarray fences, syncobjs;
if (wait) {
util_dynarray_init(&fences, NULL);
util_dynarray_init(&syncobjs, NULL);
}
hash_table_foreach(ctx->batches, hentry) {
struct panfrost_batch *batch = hentry->data;
assert(batch);
if (wait) {
panfrost_batch_fence_reference(batch->out_sync);
util_dynarray_append(&fences, struct panfrost_batch_fence *,
batch->out_sync);
util_dynarray_append(&syncobjs, uint32_t,
batch->out_sync->syncobj);
}
panfrost_batch_submit(batch);
}
@ -1200,20 +1184,6 @@ panfrost_flush_all_batches(struct panfrost_context *ctx, bool wait)
/* Collect batch fences before returning */
panfrost_gc_fences(ctx);
if (!wait)
return;
drmSyncobjWait(pan_device(ctx->base.screen)->fd,
util_dynarray_begin(&syncobjs),
util_dynarray_num_elements(&syncobjs, uint32_t),
INT64_MAX, DRM_SYNCOBJ_WAIT_FLAGS_WAIT_ALL, NULL);
util_dynarray_foreach(&fences, struct panfrost_batch_fence *, fence)
panfrost_batch_fence_unreference(*fence);
util_dynarray_fini(&fences);
util_dynarray_fini(&syncobjs);
}
bool

View File

@ -168,7 +168,7 @@ panfrost_batch_create_bo(struct panfrost_batch *batch, size_t size,
uint32_t create_flags, uint32_t access_flags);
void
panfrost_flush_all_batches(struct panfrost_context *ctx, bool wait);
panfrost_flush_all_batches(struct panfrost_context *ctx);
bool
panfrost_pending_batches_access_bo(struct panfrost_context *ctx,