]> git.karo-electronics.de Git - linux-beck.git/commitdiff
drm/amdgpu: remove sync_to from sync obj v2
authorChristian König <christian.koenig@amd.com>
Mon, 18 Jan 2016 13:49:45 +0000 (14:49 +0100)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 10 Feb 2016 19:16:52 +0000 (14:16 -0500)
Not needed any more without semaphores.

v2: remove unused variables as well

Signed-off-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Chunming Zhou <david1.zhou@amd.com>
Acked-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu.h
drivers/gpu/drm/amd/amdgpu/amdgpu_sync.c

index 297b231e4fccccb22d6cb44a85ef2ba0c54239d7..3e040cb20ebe2e19ccbd01775089c19049d43543 100644 (file)
@@ -636,7 +636,6 @@ int amdgpu_mode_dumb_mmap(struct drm_file *filp,
  * Synchronization
  */
 struct amdgpu_sync {
-       struct fence            *sync_to[AMDGPU_MAX_RINGS];
        DECLARE_HASHTABLE(fences, 4);
        struct fence            *last_vm_update;
 };
index 7f12a4d55c52339c1425cccc55b3f7baf29640c2..1d348f8ae126fdec882592b6e8ae0ca4a645d333 100644 (file)
@@ -46,11 +46,6 @@ struct amdgpu_sync_entry {
  */
 void amdgpu_sync_create(struct amdgpu_sync *sync)
 {
-       unsigned i;
-
-       for (i = 0; i < AMDGPU_MAX_RINGS; ++i)
-               sync->sync_to[i] = NULL;
-
        hash_init(sync->fences);
        sync->last_vm_update = NULL;
 }
@@ -104,7 +99,6 @@ int amdgpu_sync_fence(struct amdgpu_device *adev, struct amdgpu_sync *sync,
                      struct fence *f)
 {
        struct amdgpu_sync_entry *e;
-       struct amdgpu_fence *fence;
 
        if (!f)
                return 0;
@@ -113,27 +107,20 @@ int amdgpu_sync_fence(struct amdgpu_device *adev, struct amdgpu_sync *sync,
            amdgpu_sync_test_owner(f, AMDGPU_FENCE_OWNER_VM))
                amdgpu_sync_keep_later(&sync->last_vm_update, f);
 
-       fence = to_amdgpu_fence(f);
-       if (!fence || fence->ring->adev != adev) {
-               hash_for_each_possible(sync->fences, e, node, f->context) {
-                       if (unlikely(e->fence->context != f->context))
-                               continue;
-
-                       amdgpu_sync_keep_later(&e->fence, f);
-                       return 0;
-               }
-
-               e = kmalloc(sizeof(struct amdgpu_sync_entry), GFP_KERNEL);
-               if (!e)
-                       return -ENOMEM;
+       hash_for_each_possible(sync->fences, e, node, f->context) {
+               if (unlikely(e->fence->context != f->context))
+                       continue;
 
-               hash_add(sync->fences, &e->node, f->context);
-               e->fence = fence_get(f);
+               amdgpu_sync_keep_later(&e->fence, f);
                return 0;
        }
 
-       amdgpu_sync_keep_later(&sync->sync_to[fence->ring->idx], f);
+       e = kmalloc(sizeof(struct amdgpu_sync_entry), GFP_KERNEL);
+       if (!e)
+               return -ENOMEM;
 
+       hash_add(sync->fences, &e->node, f->context);
+       e->fence = fence_get(f);
        return 0;
 }
 
@@ -247,16 +234,6 @@ int amdgpu_sync_wait(struct amdgpu_sync *sync)
                kfree(e);
        }
 
-       for (i = 0; i < AMDGPU_MAX_RINGS; ++i) {
-               struct fence *fence = sync->sync_to[i];
-               if (!fence)
-                       continue;
-
-               r = fence_wait(fence, false);
-               if (r)
-                       return r;
-       }
-
        return 0;
 }
 
@@ -283,8 +260,5 @@ void amdgpu_sync_free(struct amdgpu_device *adev,
                kfree(e);
        }
 
-       for (i = 0; i < AMDGPU_MAX_RINGS; ++i)
-               fence_put(sync->sync_to[i]);
-
        fence_put(sync->last_vm_update);
 }