drm/amdgpu: cleanup scheduler command submission
Unify the two code path again, cause they do pretty much the same thing. Signed-off-by: Christian König <christian.koenig@amd.com> Reviewed-by: Chunming Zhou <davdi1.zhou@amd.com> Reviewed-by: Junwei Zhang <Jerry.Zhang@amd.com>
This commit is contained in:
parent
2269a39579
commit
984810fc45
@ -1210,6 +1210,7 @@ struct amdgpu_cs_parser {
|
|||||||
/* relocations */
|
/* relocations */
|
||||||
struct amdgpu_bo_list_entry *vm_bos;
|
struct amdgpu_bo_list_entry *vm_bos;
|
||||||
struct list_head validated;
|
struct list_head validated;
|
||||||
|
struct fence *fence;
|
||||||
|
|
||||||
struct amdgpu_ib *ibs;
|
struct amdgpu_ib *ibs;
|
||||||
uint32_t num_ibs;
|
uint32_t num_ibs;
|
||||||
|
@ -439,8 +439,18 @@ static int cmp_size_smaller_first(void *priv, struct list_head *a,
|
|||||||
return (int)la->robj->tbo.num_pages - (int)lb->robj->tbo.num_pages;
|
return (int)la->robj->tbo.num_pages - (int)lb->robj->tbo.num_pages;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void amdgpu_cs_parser_fini_early(struct amdgpu_cs_parser *parser, int error, bool backoff)
|
/**
|
||||||
|
* cs_parser_fini() - clean parser states
|
||||||
|
* @parser: parser structure holding parsing context.
|
||||||
|
* @error: error number
|
||||||
|
*
|
||||||
|
* If error is set than unvalidate buffer, otherwise just free memory
|
||||||
|
* used by parsing context.
|
||||||
|
**/
|
||||||
|
static void amdgpu_cs_parser_fini(struct amdgpu_cs_parser *parser, int error, bool backoff)
|
||||||
{
|
{
|
||||||
|
unsigned i;
|
||||||
|
|
||||||
if (!error) {
|
if (!error) {
|
||||||
/* Sort the buffer list from the smallest to largest buffer,
|
/* Sort the buffer list from the smallest to largest buffer,
|
||||||
* which affects the order of buffers in the LRU list.
|
* which affects the order of buffers in the LRU list.
|
||||||
@ -456,16 +466,12 @@ static void amdgpu_cs_parser_fini_early(struct amdgpu_cs_parser *parser, int err
|
|||||||
|
|
||||||
ttm_eu_fence_buffer_objects(&parser->ticket,
|
ttm_eu_fence_buffer_objects(&parser->ticket,
|
||||||
&parser->validated,
|
&parser->validated,
|
||||||
&parser->ibs[parser->num_ibs-1].fence->base);
|
parser->fence);
|
||||||
} else if (backoff) {
|
} else if (backoff) {
|
||||||
ttm_eu_backoff_reservation(&parser->ticket,
|
ttm_eu_backoff_reservation(&parser->ticket,
|
||||||
&parser->validated);
|
&parser->validated);
|
||||||
}
|
}
|
||||||
}
|
fence_put(parser->fence);
|
||||||
|
|
||||||
static void amdgpu_cs_parser_fini_late(struct amdgpu_cs_parser *parser)
|
|
||||||
{
|
|
||||||
unsigned i;
|
|
||||||
|
|
||||||
if (parser->ctx)
|
if (parser->ctx)
|
||||||
amdgpu_ctx_put(parser->ctx);
|
amdgpu_ctx_put(parser->ctx);
|
||||||
@ -484,20 +490,6 @@ static void amdgpu_cs_parser_fini_late(struct amdgpu_cs_parser *parser)
|
|||||||
drm_gem_object_unreference_unlocked(&parser->uf.bo->gem_base);
|
drm_gem_object_unreference_unlocked(&parser->uf.bo->gem_base);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* cs_parser_fini() - clean parser states
|
|
||||||
* @parser: parser structure holding parsing context.
|
|
||||||
* @error: error number
|
|
||||||
*
|
|
||||||
* If error is set than unvalidate buffer, otherwise just free memory
|
|
||||||
* used by parsing context.
|
|
||||||
**/
|
|
||||||
static void amdgpu_cs_parser_fini(struct amdgpu_cs_parser *parser, int error, bool backoff)
|
|
||||||
{
|
|
||||||
amdgpu_cs_parser_fini_early(parser, error, backoff);
|
|
||||||
amdgpu_cs_parser_fini_late(parser);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int amdgpu_bo_vm_update_pte(struct amdgpu_cs_parser *p,
|
static int amdgpu_bo_vm_update_pte(struct amdgpu_cs_parser *p,
|
||||||
struct amdgpu_vm *vm)
|
struct amdgpu_vm *vm)
|
||||||
{
|
{
|
||||||
@ -582,15 +574,9 @@ static int amdgpu_cs_ib_vm_chunk(struct amdgpu_device *adev,
|
|||||||
}
|
}
|
||||||
|
|
||||||
r = amdgpu_bo_vm_update_pte(parser, vm);
|
r = amdgpu_bo_vm_update_pte(parser, vm);
|
||||||
if (r) {
|
if (!r)
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
amdgpu_cs_sync_rings(parser);
|
amdgpu_cs_sync_rings(parser);
|
||||||
if (!amdgpu_enable_scheduler)
|
|
||||||
r = amdgpu_ib_schedule(adev, parser->num_ibs, parser->ibs,
|
|
||||||
parser->filp);
|
|
||||||
|
|
||||||
out:
|
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -881,7 +867,7 @@ int amdgpu_cs_ioctl(struct drm_device *dev, void *data, struct drm_file *filp)
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
job->base.s_fence = fence;
|
job->base.s_fence = fence;
|
||||||
fence_get(&fence->base);
|
parser.fence = fence_get(&fence->base);
|
||||||
|
|
||||||
cs->out.handle = amdgpu_ctx_add_fence(parser.ctx, ring,
|
cs->out.handle = amdgpu_ctx_add_fence(parser.ctx, ring,
|
||||||
&fence->base);
|
&fence->base);
|
||||||
@ -890,17 +876,16 @@ int amdgpu_cs_ioctl(struct drm_device *dev, void *data, struct drm_file *filp)
|
|||||||
trace_amdgpu_cs_ioctl(job);
|
trace_amdgpu_cs_ioctl(job);
|
||||||
amd_sched_entity_push_job(&job->base);
|
amd_sched_entity_push_job(&job->base);
|
||||||
|
|
||||||
list_sort(NULL, &parser.validated, cmp_size_smaller_first);
|
} else {
|
||||||
ttm_eu_fence_buffer_objects(&parser.ticket, &parser.validated,
|
struct amdgpu_fence *fence;
|
||||||
&fence->base);
|
|
||||||
fence_put(&fence->base);
|
|
||||||
|
|
||||||
amdgpu_cs_parser_fini_late(&parser);
|
r = amdgpu_ib_schedule(adev, parser.num_ibs, parser.ibs,
|
||||||
mutex_unlock(&vm->mutex);
|
parser.filp);
|
||||||
return 0;
|
fence = parser.ibs[parser.num_ibs - 1].fence;
|
||||||
|
parser.fence = fence_get(&fence->base);
|
||||||
|
cs->out.handle = parser.ibs[parser.num_ibs - 1].sequence;
|
||||||
}
|
}
|
||||||
|
|
||||||
cs->out.handle = parser.ibs[parser.num_ibs - 1].sequence;
|
|
||||||
out:
|
out:
|
||||||
amdgpu_cs_parser_fini(&parser, r, reserved_buffers);
|
amdgpu_cs_parser_fini(&parser, r, reserved_buffers);
|
||||||
mutex_unlock(&vm->mutex);
|
mutex_unlock(&vm->mutex);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user