diff options
author | Boris Brezillon <[email protected]> | 2019-09-05 18:57:11 +0200 |
---|---|---|
committer | Boris Brezillon <[email protected]> | 2019-09-13 16:25:06 +0200 |
commit | e5c7701a0a9be29efd8a8947ae55392455a3b6e7 (patch) | |
tree | 0fe192eacf2dc6f948cae8e152fdfa40d7bb02b8 | |
parent | bc0f6c0b152a70a0092cd79dde1de3e5f93aa924 (diff) |
panfrost: Pass a batch to panfrost_set_value_job()
So we can emit SET_VALUE jobs for a batch that's not currently bound
to the context.
Signed-off-by: Boris Brezillon <[email protected]>
Reviewed-by: Alyssa Rosenzweig <[email protected]>
-rw-r--r-- | src/gallium/drivers/panfrost/pan_scoreboard.c | 6 |
1 files changed, 2 insertions, 4 deletions
diff --git a/src/gallium/drivers/panfrost/pan_scoreboard.c b/src/gallium/drivers/panfrost/pan_scoreboard.c index f0771a2c5b5..f340bb62662 100644 --- a/src/gallium/drivers/panfrost/pan_scoreboard.c +++ b/src/gallium/drivers/panfrost/pan_scoreboard.c @@ -270,7 +270,7 @@ panfrost_scoreboard_queue_fused_job_prepend( /* Generates a set value job, used below as part of TILER job scheduling. */ static struct panfrost_transfer -panfrost_set_value_job(struct panfrost_context *ctx, mali_ptr polygon_list) +panfrost_set_value_job(struct panfrost_batch *batch, mali_ptr polygon_list) { struct mali_job_descriptor_header job = { .job_type = JOB_TYPE_SET_VALUE, @@ -282,7 +282,6 @@ panfrost_set_value_job(struct panfrost_context *ctx, mali_ptr polygon_list) .unknown = 0x3, }; - struct panfrost_batch *batch = panfrost_get_batch_for_fbo(ctx); struct panfrost_transfer transfer = panfrost_allocate_transient(batch, sizeof(job) + sizeof(payload)); memcpy(transfer.cpu, &job, sizeof(job)); memcpy(transfer.cpu + sizeof(job), &payload, sizeof(payload)); @@ -303,11 +302,10 @@ panfrost_scoreboard_set_value(struct panfrost_batch *batch) /* Okay, we do. Let's generate it. We'll need the job's polygon list * regardless of size. */ - struct panfrost_context *ctx = batch->ctx; mali_ptr polygon_list = panfrost_batch_get_polygon_list(batch, 0); struct panfrost_transfer job = - panfrost_set_value_job(ctx, polygon_list); + panfrost_set_value_job(batch, polygon_list); /* Queue it */ panfrost_scoreboard_queue_compute_job(batch, job); |