OSDN Git Service

drm/ttm: replace dma_resv object on deleted BOs v3
authorChristian König <christian.koenig@amd.com>
Mon, 11 Nov 2019 14:16:56 +0000 (15:16 +0100)
committerChristian König <christian.koenig@amd.com>
Wed, 12 Feb 2020 12:03:33 +0000 (13:03 +0100)
When non-imported BOs are resurrected for delayed delete we replace
the dma_resv object to allow for easy reclaiming of the resources.

v2: move that to ttm_bo_individualize_resv
v3: add a comment to explain what's going on

Signed-off-by: Christian König <christian.koenig@amd.com>
Reviewed-by: xinhui pan <xinhui.pan@amd.com>
Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Link: https://patchwork.freedesktop.org/patch/352927/
drivers/gpu/drm/ttm/ttm_bo.c

index 28fd91c..6688599 100644 (file)
@@ -393,6 +393,18 @@ static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
 
        r = dma_resv_copy_fences(&bo->base._resv, bo->base.resv);
        dma_resv_unlock(&bo->base._resv);
+       if (r)
+               return r;
+
+       if (bo->type != ttm_bo_type_sg) {
+               /* This works because the BO is about to be destroyed and nobody
+                * reference it any more. The only tricky case is the trylock on
+                * the resv object while holding the lru_lock.
+                */
+               spin_lock(&ttm_bo_glob.lru_lock);
+               bo->base.resv = &bo->base._resv;
+               spin_unlock(&ttm_bo_glob.lru_lock);
+       }
 
        return r;
 }
@@ -720,7 +732,7 @@ static bool ttm_bo_evict_swapout_allowable(struct ttm_buffer_object *bo,
 
        if (bo->base.resv == ctx->resv) {
                dma_resv_assert_held(bo->base.resv);
-               if (ctx->flags & TTM_OPT_FLAG_ALLOW_RES_EVICT || bo->deleted)
+               if (ctx->flags & TTM_OPT_FLAG_ALLOW_RES_EVICT)
                        ret = true;
                *locked = false;
                if (busy)