dma-buf: allow reserving more than one shared fence slot
authorChristian König <christian.koenig@amd.com>
Wed, 19 Sep 2018 14:12:25 +0000 (16:12 +0200)
committerChristian König <christian.koenig@amd.com>
Thu, 25 Oct 2018 11:45:07 +0000 (13:45 +0200)
Let's support simultaneous submissions to multiple engines.

Signed-off-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
Reviewed-by: Junwei Zhang <Jerry.Zhang@amd.com>
Reviewed-by: Huang Rui <ray.huang@amd.com>
Link: https://patchwork.kernel.org/patch/10626149/
16 files changed:
drivers/dma-buf/reservation.c
drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c
drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
drivers/gpu/drm/etnaviv/etnaviv_gem_submit.c
drivers/gpu/drm/i915/i915_vma.c
drivers/gpu/drm/msm/msm_gem_submit.c
drivers/gpu/drm/nouveau/nouveau_fence.c
drivers/gpu/drm/qxl/qxl_release.c
drivers/gpu/drm/radeon/radeon_vm.c
drivers/gpu/drm/ttm/ttm_bo.c
drivers/gpu/drm/ttm/ttm_execbuf_util.c
drivers/gpu/drm/v3d/v3d_gem.c
drivers/gpu/drm/vc4/vc4_gem.c
drivers/gpu/drm/vgem/vgem_fence.c
include/linux/reservation.h

index 5825fc336a138112f46b27b83e5231e81a6f2b17..5fb4fd461908d5794232a67648d4d908c05b0557 100644 (file)
@@ -56,9 +56,10 @@ const char reservation_seqcount_string[] = "reservation_seqcount";
 EXPORT_SYMBOL(reservation_seqcount_string);
 
 /**
- * reservation_object_reserve_shared - Reserve space to add a shared
- * fence to a reservation_object.
+ * reservation_object_reserve_shared - Reserve space to add shared fences to
+ * a reservation_object.
  * @obj: reservation object
+ * @num_fences: number of fences we want to add
  *
  * Should be called before reservation_object_add_shared_fence().  Must
  * be called with obj->lock held.
@@ -66,7 +67,8 @@ EXPORT_SYMBOL(reservation_seqcount_string);
  * RETURNS
  * Zero for success, or -errno
  */
-int reservation_object_reserve_shared(struct reservation_object *obj)
+int reservation_object_reserve_shared(struct reservation_object *obj,
+                                     unsigned int num_fences)
 {
        struct reservation_object_list *old, *new;
        unsigned int i, j, k, max;
@@ -74,10 +76,11 @@ int reservation_object_reserve_shared(struct reservation_object *obj)
        old = reservation_object_get_list(obj);
 
        if (old && old->shared_max) {
-               if (old->shared_count < old->shared_max)
+               if ((old->shared_count + num_fences) <= old->shared_max)
                        return 0;
                else
-                       max = old->shared_max * 2;
+                       max = max(old->shared_count + num_fences,
+                                 old->shared_max * 2);
        } else {
                max = 4;
        }
index 8e9a65a1587576d25a421bb9842e0fd68583adc7..35bc8fc3bc701d965291bda7435835175982c5e3 100644 (file)
@@ -955,7 +955,7 @@ static int amdgpu_cs_vm_handling(struct amdgpu_cs_parser *p)
        if (r)
                return r;
 
-       r = reservation_object_reserve_shared(vm->root.base.bo->tbo.resv);
+       r = reservation_object_reserve_shared(vm->root.base.bo->tbo.resv, 1);
        if (r)
                return r;
 
index 904014dc5915f8142dd0dc6c169a76bacbaf7e9f..cf768acb51dce3f43efc48779d29ecdeda971846 100644 (file)
@@ -640,7 +640,7 @@ int amdgpu_bo_backup_to_shadow(struct amdgpu_device *adev,
        bo_addr = amdgpu_bo_gpu_offset(bo);
        shadow_addr = amdgpu_bo_gpu_offset(bo->shadow);
 
-       r = reservation_object_reserve_shared(bo->tbo.resv);
+       r = reservation_object_reserve_shared(bo->tbo.resv, 1);
        if (r)
                goto err;
 
index 6904d794d60a7a5c06057f74cf930db06a01e195..bdce05183edbe59e246a63d8a81c21bae9bc1af9 100644 (file)
@@ -772,7 +772,7 @@ static int amdgpu_vm_clear_bo(struct amdgpu_device *adev,
 
        ring = container_of(vm->entity.rq->sched, struct amdgpu_ring, sched);
 
-       r = reservation_object_reserve_shared(bo->tbo.resv);
+       r = reservation_object_reserve_shared(bo->tbo.resv, 1);
        if (r)
                return r;
 
@@ -1839,7 +1839,7 @@ static int amdgpu_vm_bo_update_mapping(struct amdgpu_device *adev,
        if (r)
                goto error_free;
 
-       r = reservation_object_reserve_shared(vm->root.base.bo->tbo.resv);
+       r = reservation_object_reserve_shared(vm->root.base.bo->tbo.resv, 1);
        if (r)
                goto error_free;
 
index 983e67f19e4508b5023cb5efba221981f4a9b4b0..30875f8f293371ccd240be02b826302a8abeed08 100644 (file)
@@ -179,7 +179,7 @@ static int submit_fence_sync(struct etnaviv_gem_submit *submit)
                struct reservation_object *robj = bo->obj->resv;
 
                if (!(bo->flags & ETNA_SUBMIT_BO_WRITE)) {
-                       ret = reservation_object_reserve_shared(robj);
+                       ret = reservation_object_reserve_shared(robj, 1);
                        if (ret)
                                return ret;
                }
index 31efc971a3a83897b545c49142fc0e1366641521..35fce4c88629ea4b61187819194f08767e1bb71e 100644 (file)
@@ -892,7 +892,7 @@ static void export_fence(struct i915_vma *vma,
        reservation_object_lock(resv, NULL);
        if (flags & EXEC_OBJECT_WRITE)
                reservation_object_add_excl_fence(resv, &rq->fence);
-       else if (reservation_object_reserve_shared(resv) == 0)
+       else if (reservation_object_reserve_shared(resv, 1) == 0)
                reservation_object_add_shared_fence(resv, &rq->fence);
        reservation_object_unlock(resv);
 }
index 7a7923e6220da89b252997d9f9bb674e0b7802dd..a90aedd6883a8692bc68d5353b17049e4f1a3faf 100644 (file)
@@ -241,7 +241,8 @@ static int submit_fence_sync(struct msm_gem_submit *submit, bool no_implicit)
                         * strange place to call it.  OTOH this is a
                         * convenient can-fail point to hook it in.
                         */
-                       ret = reservation_object_reserve_shared(msm_obj->resv);
+                       ret = reservation_object_reserve_shared(msm_obj->resv,
+                                                               1);
                        if (ret)
                                return ret;
                }
index 99be61ddeb75843621c7ed2b36c1c7974d805769..d4964f3397a134aab44b05b7f3852c7157978a8c 100644 (file)
@@ -341,7 +341,7 @@ nouveau_fence_sync(struct nouveau_bo *nvbo, struct nouveau_channel *chan, bool e
        int ret = 0, i;
 
        if (!exclusive) {
-               ret = reservation_object_reserve_shared(resv);
+               ret = reservation_object_reserve_shared(resv, 1);
 
                if (ret)
                        return ret;
index e37f0097f7441323281b8e06f76a04e1104ab260..a8d5457a1af92dbd5c37d38d30c1beff18d1ae31 100644 (file)
@@ -234,7 +234,7 @@ static int qxl_release_validate_bo(struct qxl_bo *bo)
                        return ret;
        }
 
-       ret = reservation_object_reserve_shared(bo->tbo.resv);
+       ret = reservation_object_reserve_shared(bo->tbo.resv, 1);
        if (ret)
                return ret;
 
index 7f1a9c787bd1325ec5b2a50b982f8aa69fec2438..fed11ece0de6e22ca57090dbbf709c0bbb9bfcc3 100644 (file)
@@ -831,7 +831,7 @@ static int radeon_vm_update_ptes(struct radeon_device *rdev,
                int r;
 
                radeon_sync_resv(rdev, &ib->sync, pt->tbo.resv, true);
-               r = reservation_object_reserve_shared(pt->tbo.resv);
+               r = reservation_object_reserve_shared(pt->tbo.resv, 1);
                if (r)
                        return r;
 
index 26b889f866707eaaed398e593b3be6bfcd775d14..83b4657ffb107aff31997fca9c2fb51836b1087c 100644 (file)
@@ -872,7 +872,7 @@ static int ttm_bo_add_move_fence(struct ttm_buffer_object *bo,
        if (fence) {
                reservation_object_add_shared_fence(bo->resv, fence);
 
-               ret = reservation_object_reserve_shared(bo->resv);
+               ret = reservation_object_reserve_shared(bo->resv, 1);
                if (unlikely(ret))
                        return ret;
 
@@ -977,7 +977,7 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
        bool has_erestartsys = false;
        int i, ret;
 
-       ret = reservation_object_reserve_shared(bo->resv);
+       ret = reservation_object_reserve_shared(bo->resv, 1);
        if (unlikely(ret))
                return ret;
 
index e73ae0d228976f6708cffcaa5602133fec0a2c22..e493edb0d3e71299de52b4fceec4f6ac59afe9c2 100644 (file)
@@ -129,7 +129,7 @@ int ttm_eu_reserve_buffers(struct ww_acquire_ctx *ticket,
                        if (!entry->shared)
                                continue;
 
-                       ret = reservation_object_reserve_shared(bo->resv);
+                       ret = reservation_object_reserve_shared(bo->resv, 1);
                        if (!ret)
                                continue;
                }
@@ -151,7 +151,7 @@ int ttm_eu_reserve_buffers(struct ww_acquire_ctx *ticket,
                }
 
                if (!ret && entry->shared)
-                       ret = reservation_object_reserve_shared(bo->resv);
+                       ret = reservation_object_reserve_shared(bo->resv, 1);
 
                if (unlikely(ret != 0)) {
                        if (ret == -EINTR)
index e688369ca82b9fcaf3725ca45e3f125f38224fb2..b88c9691145390702a4ec7b3e9ef063fb9d84d1a 100644 (file)
@@ -305,7 +305,7 @@ retry:
        for (i = 0; i < exec->bo_count; i++) {
                bo = to_v3d_bo(&exec->bo[i]->base);
 
-               ret = reservation_object_reserve_shared(bo->resv);
+               ret = reservation_object_reserve_shared(bo->resv, 1);
                if (ret) {
                        v3d_unlock_bo_reservations(dev, exec, acquire_ctx);
                        return ret;
index 251198194c38863b032256460e5ed554662c066c..41881ce4132dd3cec5b1a6b214c386592d854761 100644 (file)
@@ -635,7 +635,7 @@ retry:
        for (i = 0; i < exec->bo_count; i++) {
                bo = to_vc4_bo(&exec->bo[i]->base);
 
-               ret = reservation_object_reserve_shared(bo->resv);
+               ret = reservation_object_reserve_shared(bo->resv, 1);
                if (ret) {
                        vc4_unlock_bo_reservations(dev, exec, acquire_ctx);
                        return ret;
index e6ee71323a66bfe762a1aa7c3294ad0aa08cc657..c1c420afe2dd130af9b4faf1df1fa649c1820f92 100644 (file)
@@ -180,7 +180,7 @@ int vgem_fence_attach_ioctl(struct drm_device *dev,
        reservation_object_lock(resv, NULL);
        if (arg->flags & VGEM_FENCE_WRITE)
                reservation_object_add_excl_fence(resv, fence);
-       else if ((ret = reservation_object_reserve_shared(resv)) == 0)
+       else if ((ret = reservation_object_reserve_shared(resv, 1)) == 0)
                reservation_object_add_shared_fence(resv, fence);
        reservation_object_unlock(resv);
 
index 54cf6773a14ccc75ce84e653d79182e9d4be9d70..5ddb0e143721f46b14ff72343d2806079ef07b3d 100644 (file)
@@ -261,7 +261,8 @@ reservation_object_get_excl_rcu(struct reservation_object *obj)
        return fence;
 }
 
-int reservation_object_reserve_shared(struct reservation_object *obj);
+int reservation_object_reserve_shared(struct reservation_object *obj,
+                                     unsigned int num_fences);
 void reservation_object_add_shared_fence(struct reservation_object *obj,
                                         struct dma_fence *fence);