drm/virtio: Wait for each dma-fence of in-fence array individually
authorDmitry Osipenko <dmitry.osipenko@collabora.com>
Sun, 16 Apr 2023 11:52:36 +0000 (14:52 +0300)
committerDmitry Osipenko <dmitry.osipenko@collabora.com>
Sat, 3 Jun 2023 01:50:50 +0000 (04:50 +0300)
Use dma-fence-unwrap API for waiting each dma-fence of the in-fence array
individually. Sync file's in-fence array always has a non-matching fence
context ID, which doesn't allow to skip waiting of fences with a matching
context ID in a case of a merged sync file fence.

Suggested-by: Rob Clark <robdclark@gmail.com>
Reviewed-by: Emil Velikov <emil.velikov@collabora.com>
Tested-by: Pierre-Eric Pelloux-Prayer <pierre-eric.pelloux-prayer@amd.com>
Signed-off-by: Dmitry Osipenko <dmitry.osipenko@collabora.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230416115237.798604-3-dmitry.osipenko@collabora.com
drivers/gpu/drm/virtio/virtgpu_submit.c

index 84e7c4d9d8c7e440251864726d7751b657b98f0d..cf3c04b16a7a8f7a813f1ccb91fc58d1d9767a02 100644 (file)
@@ -32,8 +32,8 @@ struct virtio_gpu_submit {
        void *buf;
 };
 
-static int virtio_gpu_dma_fence_wait(struct virtio_gpu_submit *submit,
-                                    struct dma_fence *in_fence)
+static int virtio_gpu_do_fence_wait(struct virtio_gpu_submit *submit,
+                                   struct dma_fence *in_fence)
 {
        u32 context = submit->fence_ctx + submit->ring_idx;
 
@@ -43,6 +43,22 @@ static int virtio_gpu_dma_fence_wait(struct virtio_gpu_submit *submit,
        return dma_fence_wait(in_fence, true);
 }
 
+static int virtio_gpu_dma_fence_wait(struct virtio_gpu_submit *submit,
+                                    struct dma_fence *fence)
+{
+       struct dma_fence_unwrap itr;
+       struct dma_fence *f;
+       int err;
+
+       dma_fence_unwrap_for_each(f, &itr, fence) {
+               err = virtio_gpu_do_fence_wait(submit, f);
+               if (err)
+                       return err;
+       }
+
+       return 0;
+}
+
 static int virtio_gpu_fence_event_create(struct drm_device *dev,
                                         struct drm_file *file,
                                         struct virtio_gpu_fence *fence,