答复: [PATCH] drm/amdgpu/scheduler: job ibs should also be freed
Qu, Jim
Jim.Qu at amd.com
Wed Oct 25 03:20:04 UTC 2017
Yeah, I saw that code.
There is a issue that will get calltrace in "ib_get" blocked by waiting_fence on RHEL6.9. I make a misunderstand to add amdgpu_job_free_resources(job). Actually, the key point is kthread_park() which is not implemented on RHEL6.9 kernel(2.6.32).
Please ignore this patch.
Thanks
JimQu
________________________________________
发件人: Liu, Monk
发送时间: 2017年10月25日 11:14
收件人: Qu, Jim; amd-gfx at lists.freedesktop.org
抄送: Qu, Jim
主题: RE: [PATCH] drm/amdgpu/scheduler: job ibs should also be freed
I don't see why we need this, can you explain more about it ?
the " amdgpu_job_free_resources(job);" should already invoked before the job pushed to scheduler, so after " amd_sched_fence_finished(s_fence);" the IB SABO
would be released
BR Monk
-----Original Message-----
From: amd-gfx [mailto:amd-gfx-bounces at lists.freedesktop.org] On Behalf Of Jim Qu
Sent: 2017年10月24日 19:31
To: amd-gfx at lists.freedesktop.org
Cc: Qu, Jim <Jim.Qu at amd.com>
Subject: [PATCH] drm/amdgpu/scheduler: job ibs should also be freed
Change-Id: I93bb283cfebfe203f777bb7bae390c9b9a7b5fd0
Signed-off-by: Jim Qu <Jim.Qu at amd.com>
---
drivers/gpu/drm/amd/scheduler/gpu_scheduler.c | 8 +++++---
1 file changed, 5 insertions(+), 3 deletions(-)
diff --git a/drivers/gpu/drm/amd/scheduler/gpu_scheduler.c b/drivers/gpu/drm/amd/scheduler/gpu_scheduler.c
index 9cbeade..0bcc737 100644
--- a/drivers/gpu/drm/amd/scheduler/gpu_scheduler.c
+++ b/drivers/gpu/drm/amd/scheduler/gpu_scheduler.c
@@ -222,18 +222,20 @@ void amd_sched_entity_fini(struct amd_gpu_scheduler *sched,
amd_sched_entity_is_idle(entity));
amd_sched_entity_set_rq(entity, NULL);
if (r) {
- struct amd_sched_job *job;
+ struct amd_sched_job *s_job;
/* Park the kernel for a moment to make sure it isn't processing
* our enity.
*/
kthread_park(sched->thread);
kthread_unpark(sched->thread);
- while ((job = to_amd_sched_job(spsc_queue_pop(&entity->job_queue)))) {
- struct amd_sched_fence *s_fence = job->s_fence;
+ while ((s_job = to_amd_sched_job(spsc_queue_pop(&entity->job_queue)))) {
+ struct amd_sched_fence *s_fence = s_job->s_fence;
+ struct amdgpu_job *job = to_amdgpu_job(s_job);
amd_sched_fence_scheduled(s_fence);
dma_fence_set_error(&s_fence->finished, -ESRCH);
+ amdgpu_job_free_resources(job);
amd_sched_fence_finished(s_fence);
}
}
--
1.9.1
_______________________________________________
amd-gfx mailing list
amd-gfx at lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx
More information about the amd-gfx
mailing list