diff options
author | Christian König <christian.koenig@amd.com> | 2016-03-15 15:40:17 +0300 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2016-03-17 00:58:52 +0300 |
commit | b44135351a3a5cfc60f5b6729445311c2d5e141c (patch) | |
tree | 68a14217f9170f07369383df32bfcefda8dcfae3 | |
parent | ca08e04d5642c429ec891fa17bf379be988dea6b (diff) | |
download | linux-b44135351a3a5cfc60f5b6729445311c2d5e141c.tar.xz |
drm/amdgpu: RCU protected amdgpu_fence_release
Fences must be freed RCU protected, otherwise the reservation_object_*_rcu()
functions can run into problems.
Signed-off-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_fence.c | 23 |
1 files changed, 22 insertions, 1 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_fence.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_fence.c index d8bbe85c22a2..ec73ab1c177d 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_fence.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_fence.c @@ -638,12 +638,33 @@ static bool amdgpu_fence_enable_signaling(struct fence *f) return true; } -static void amdgpu_fence_release(struct fence *f) +/** + * amdgpu_fence_free - free up the fence memory + * + * @rcu: RCU callback head + * + * Free up the fence memory after the RCU grace period. + */ +static void amdgpu_fence_free(struct rcu_head *rcu) { + struct fence *f = container_of(rcu, struct fence, rcu); struct amdgpu_fence *fence = to_amdgpu_fence(f); kmem_cache_free(amdgpu_fence_slab, fence); } +/** + * amdgpu_fence_release - callback that fence can be freed + * + * @fence: fence + * + * This function is called when the reference count becomes zero. + * It just RCU schedules freeing up the fence. + */ +static void amdgpu_fence_release(struct fence *f) +{ + call_rcu(&f->rcu, amdgpu_fence_free); +} + static const struct fence_ops amdgpu_fence_ops = { .get_driver_name = amdgpu_fence_get_driver_name, .get_timeline_name = amdgpu_fence_get_timeline_name, |