diff options
author | Chunming Zhou <David1.Zhou@amd.com> | 2016-06-29 23:23:31 -0400 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2016-07-07 15:06:13 -0400 |
commit | 754ce0fa55c4e464626e961ddb98f935ab85aa19 (patch) | |
tree | 489d8f3d127e768357bc6ffd8a468fa9a38bfc35 /drivers/gpu/drm/amd | |
parent | f263ec622f06c3cf2da3a29e5ad0184dc50d1c2c (diff) |
drm/amd: add parent for sched fence
Parent of sched fence is hw fence which is to signal sched fence.
Signed-off-by: Chunming Zhou <David1.Zhou@amd.com>
Reviewed-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd')
-rw-r--r-- | drivers/gpu/drm/amd/scheduler/gpu_scheduler.c | 1 | ||||
-rw-r--r-- | drivers/gpu/drm/amd/scheduler/gpu_scheduler.h | 1 | ||||
-rw-r--r-- | drivers/gpu/drm/amd/scheduler/sched_fence.c | 1 |
3 files changed, 3 insertions, 0 deletions
diff --git a/drivers/gpu/drm/amd/scheduler/gpu_scheduler.c b/drivers/gpu/drm/amd/scheduler/gpu_scheduler.c index 3405372cda0c..717655d0c642 100644 --- a/drivers/gpu/drm/amd/scheduler/gpu_scheduler.c +++ b/drivers/gpu/drm/amd/scheduler/gpu_scheduler.c | |||
@@ -516,6 +516,7 @@ static int amd_sched_main(void *param) | |||
516 | fence = sched->ops->run_job(sched_job); | 516 | fence = sched->ops->run_job(sched_job); |
517 | amd_sched_fence_scheduled(s_fence); | 517 | amd_sched_fence_scheduled(s_fence); |
518 | if (fence) { | 518 | if (fence) { |
519 | s_fence->parent = fence_get(fence); | ||
519 | r = fence_add_callback(fence, &s_fence->cb, | 520 | r = fence_add_callback(fence, &s_fence->cb, |
520 | amd_sched_process_job); | 521 | amd_sched_process_job); |
521 | if (r == -ENOENT) | 522 | if (r == -ENOENT) |
diff --git a/drivers/gpu/drm/amd/scheduler/gpu_scheduler.h b/drivers/gpu/drm/amd/scheduler/gpu_scheduler.h index 9024dc5592e3..545fda73a05f 100644 --- a/drivers/gpu/drm/amd/scheduler/gpu_scheduler.h +++ b/drivers/gpu/drm/amd/scheduler/gpu_scheduler.h | |||
@@ -69,6 +69,7 @@ struct amd_sched_fence { | |||
69 | struct fence scheduled; | 69 | struct fence scheduled; |
70 | struct fence finished; | 70 | struct fence finished; |
71 | struct fence_cb cb; | 71 | struct fence_cb cb; |
72 | struct fence *parent; | ||
72 | struct amd_gpu_scheduler *sched; | 73 | struct amd_gpu_scheduler *sched; |
73 | spinlock_t lock; | 74 | spinlock_t lock; |
74 | void *owner; | 75 | void *owner; |
diff --git a/drivers/gpu/drm/amd/scheduler/sched_fence.c b/drivers/gpu/drm/amd/scheduler/sched_fence.c index a5e3fef622fb..6b63beaf7574 100644 --- a/drivers/gpu/drm/amd/scheduler/sched_fence.c +++ b/drivers/gpu/drm/amd/scheduler/sched_fence.c | |||
@@ -98,6 +98,7 @@ static void amd_sched_fence_free(struct rcu_head *rcu) | |||
98 | struct fence *f = container_of(rcu, struct fence, rcu); | 98 | struct fence *f = container_of(rcu, struct fence, rcu); |
99 | struct amd_sched_fence *fence = to_amd_sched_fence(f); | 99 | struct amd_sched_fence *fence = to_amd_sched_fence(f); |
100 | 100 | ||
101 | fence_put(fence->parent); | ||
101 | kmem_cache_free(sched_fence_slab, fence); | 102 | kmem_cache_free(sched_fence_slab, fence); |
102 | } | 103 | } |
103 | 104 | ||