drm/amdgpu: return new seq_no for amd_sched_push_job
It is clean to update last_queued_v_seq in the scheduler module Signed-off-by: Jammy Zhou <Jammy.Zhou@amd.com> Reviewed-by: Christian König <christian.koenig@amd.com> Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
@@ -907,8 +907,6 @@ int amdgpu_cs_ioctl(struct drm_device *dev, void *data, struct drm_file *filp)
|
||||
if (amdgpu_enable_scheduler && parser->num_ibs) {
|
||||
struct amdgpu_ring * ring =
|
||||
amdgpu_cs_parser_get_ring(adev, parser);
|
||||
parser->ibs[parser->num_ibs - 1].sequence = atomic64_inc_return(
|
||||
&parser->ctx->rings[ring->idx].c_entity.last_queued_v_seq);
|
||||
if (ring->is_pte_ring || (parser->bo_list && parser->bo_list->has_userptr)) {
|
||||
r = amdgpu_cs_parser_prepare_job(parser);
|
||||
if (r)
|
||||
@@ -918,7 +916,8 @@ int amdgpu_cs_ioctl(struct drm_device *dev, void *data, struct drm_file *filp)
|
||||
parser->ring = ring;
|
||||
parser->run_job = amdgpu_cs_parser_run_job;
|
||||
parser->free_job = amdgpu_cs_parser_free_job;
|
||||
amd_sched_push_job(ring->scheduler,
|
||||
parser->ibs[parser->num_ibs - 1].sequence =
|
||||
amd_sched_push_job(ring->scheduler,
|
||||
&parser->ctx->rings[ring->idx].c_entity,
|
||||
parser);
|
||||
cs->out.handle = parser->ibs[parser->num_ibs - 1].sequence;
|
||||
|
||||
@@ -109,7 +109,6 @@ int amdgpu_sched_ib_submit_kernel_helper(struct amdgpu_device *adev,
|
||||
{
|
||||
int r = 0;
|
||||
if (amdgpu_enable_scheduler) {
|
||||
uint64_t v_seq;
|
||||
struct amdgpu_cs_parser *sched_job =
|
||||
amdgpu_cs_parser_create(adev,
|
||||
owner,
|
||||
@@ -119,16 +118,12 @@ int amdgpu_sched_ib_submit_kernel_helper(struct amdgpu_device *adev,
|
||||
return -ENOMEM;
|
||||
}
|
||||
sched_job->free_job = free_job;
|
||||
v_seq = atomic64_inc_return(&adev->kernel_ctx->rings[ring->idx].c_entity.last_queued_v_seq);
|
||||
ibs[num_ibs - 1].sequence = v_seq;
|
||||
amd_sched_push_job(ring->scheduler,
|
||||
ibs[num_ibs - 1].sequence = amd_sched_push_job(ring->scheduler,
|
||||
&adev->kernel_ctx->rings[ring->idx].c_entity,
|
||||
sched_job);
|
||||
r = amd_sched_wait_emit(
|
||||
&adev->kernel_ctx->rings[ring->idx].c_entity,
|
||||
v_seq,
|
||||
false,
|
||||
-1);
|
||||
ibs[num_ibs - 1].sequence, false, -1);
|
||||
if (r)
|
||||
WARN(true, "emit timeout\n");
|
||||
} else
|
||||
|
||||
@@ -371,7 +371,6 @@ static int amdgpu_vm_clear_bo(struct amdgpu_device *adev,
|
||||
|
||||
if (amdgpu_enable_scheduler) {
|
||||
int r;
|
||||
uint64_t v_seq;
|
||||
sched_job = amdgpu_cs_parser_create(adev, AMDGPU_FENCE_OWNER_VM,
|
||||
adev->kernel_ctx, ib, 1);
|
||||
if(!sched_job)
|
||||
@@ -379,15 +378,11 @@ static int amdgpu_vm_clear_bo(struct amdgpu_device *adev,
|
||||
sched_job->job_param.vm.bo = bo;
|
||||
sched_job->run_job = amdgpu_vm_run_job;
|
||||
sched_job->free_job = amdgpu_vm_free_job;
|
||||
v_seq = atomic64_inc_return(&adev->kernel_ctx->rings[ring->idx].c_entity.last_queued_v_seq);
|
||||
ib->sequence = v_seq;
|
||||
amd_sched_push_job(ring->scheduler,
|
||||
ib->sequence = amd_sched_push_job(ring->scheduler,
|
||||
&adev->kernel_ctx->rings[ring->idx].c_entity,
|
||||
sched_job);
|
||||
r = amd_sched_wait_emit(&adev->kernel_ctx->rings[ring->idx].c_entity,
|
||||
v_seq,
|
||||
false,
|
||||
-1);
|
||||
ib->sequence, false, -1);
|
||||
if (r)
|
||||
DRM_ERROR("emit timeout\n");
|
||||
|
||||
@@ -521,7 +516,6 @@ int amdgpu_vm_update_page_directory(struct amdgpu_device *adev,
|
||||
|
||||
if (amdgpu_enable_scheduler) {
|
||||
int r;
|
||||
uint64_t v_seq;
|
||||
sched_job = amdgpu_cs_parser_create(adev, AMDGPU_FENCE_OWNER_VM,
|
||||
adev->kernel_ctx,
|
||||
ib, 1);
|
||||
@@ -530,15 +524,11 @@ int amdgpu_vm_update_page_directory(struct amdgpu_device *adev,
|
||||
sched_job->job_param.vm.bo = pd;
|
||||
sched_job->run_job = amdgpu_vm_run_job;
|
||||
sched_job->free_job = amdgpu_vm_free_job;
|
||||
v_seq = atomic64_inc_return(&adev->kernel_ctx->rings[ring->idx].c_entity.last_queued_v_seq);
|
||||
ib->sequence = v_seq;
|
||||
amd_sched_push_job(ring->scheduler,
|
||||
ib->sequence = amd_sched_push_job(ring->scheduler,
|
||||
&adev->kernel_ctx->rings[ring->idx].c_entity,
|
||||
sched_job);
|
||||
r = amd_sched_wait_emit(&adev->kernel_ctx->rings[ring->idx].c_entity,
|
||||
v_seq,
|
||||
false,
|
||||
-1);
|
||||
ib->sequence, false, -1);
|
||||
if (r)
|
||||
DRM_ERROR("emit timeout\n");
|
||||
} else {
|
||||
@@ -872,7 +862,6 @@ static int amdgpu_vm_bo_update_mapping(struct amdgpu_device *adev,
|
||||
|
||||
if (amdgpu_enable_scheduler) {
|
||||
int r;
|
||||
uint64_t v_seq;
|
||||
sched_job = amdgpu_cs_parser_create(adev, AMDGPU_FENCE_OWNER_VM,
|
||||
adev->kernel_ctx, ib, 1);
|
||||
if(!sched_job)
|
||||
@@ -883,15 +872,11 @@ static int amdgpu_vm_bo_update_mapping(struct amdgpu_device *adev,
|
||||
sched_job->job_param.vm_mapping.fence = fence;
|
||||
sched_job->run_job = amdgpu_vm_bo_update_mapping_run_job;
|
||||
sched_job->free_job = amdgpu_vm_free_job;
|
||||
v_seq = atomic64_inc_return(&adev->kernel_ctx->rings[ring->idx].c_entity.last_queued_v_seq);
|
||||
ib->sequence = v_seq;
|
||||
amd_sched_push_job(ring->scheduler,
|
||||
ib->sequence = amd_sched_push_job(ring->scheduler,
|
||||
&adev->kernel_ctx->rings[ring->idx].c_entity,
|
||||
sched_job);
|
||||
r = amd_sched_wait_emit(&adev->kernel_ctx->rings[ring->idx].c_entity,
|
||||
v_seq,
|
||||
false,
|
||||
-1);
|
||||
ib->sequence, false, -1);
|
||||
if (r)
|
||||
DRM_ERROR("emit timeout\n");
|
||||
} else {
|
||||
|
||||
Reference in New Issue
Block a user