]> Git Repo - linux.git/blobdiff - drivers/gpu/drm/amd/amdgpu/amdgpu_sync.c
Merge tag 'for-linus-4.2-rc0-tag' of git://git.kernel.org/pub/scm/linux/kernel/git...
[linux.git] / drivers / gpu / drm / amd / amdgpu / amdgpu_sync.c
index 855d56ac7115bdc59a7b5c440b80b1cb40992c0f..21accbdd0a1afc0bc494dcafd4db39d44fdbe0a5 100644 (file)
@@ -101,6 +101,9 @@ int amdgpu_sync_resv(struct amdgpu_device *adev,
        unsigned i;
        int r = 0;
 
+       if (resv == NULL)
+               return -EINVAL;
+
        /* always sync to the exclusive fence */
        f = reservation_object_get_excl(resv);
        fence = f ? to_amdgpu_fence(f) : NULL;
@@ -116,12 +119,12 @@ int amdgpu_sync_resv(struct amdgpu_device *adev,
        for (i = 0; i < flist->shared_count; ++i) {
                f = rcu_dereference_protected(flist->shared[i],
                                              reservation_object_held(resv));
-               fence = to_amdgpu_fence(f);
+               fence = f ? to_amdgpu_fence(f) : NULL;
                if (fence && fence->ring->adev == adev) {
                        if (fence->owner != owner ||
                            fence->owner == AMDGPU_FENCE_OWNER_UNDEFINED)
                                amdgpu_sync_fence(sync, fence);
-               } else {
+               } else if (f) {
                        r = fence_wait(f, true);
                        if (r)
                                break;
This page took 0.039449 seconds and 4 git commands to generate.