drm/ttm: revise ttm_bo_move_to_lru_tail to support bulk moves
authorChristian König <christian.koenig@amd.com>
Mon, 6 Aug 2018 09:05:30 +0000 (17:05 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Mon, 27 Aug 2018 16:11:21 +0000 (11:11 -0500)
When move a BO to the end of LRU, it need remember the BO positions.
Make sure all moved bo in between "first" and "last". And they will be bulk
moving together.

Signed-off-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Huang Rui <ray.huang@amd.com>
Tested-by: Mike Lothian <mike@fireburn.co.uk>
Tested-by: Dieter Nützel <Dieter@nuetzel-hh.de>
Acked-by: Chunming Zhou <david1.zhou@amd.com>
Reviewed-by: Junwei Zhang <Jerry.Zhang@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
drivers/gpu/drm/ttm/ttm_bo.c
include/drm/ttm/ttm_bo_api.h

index 7d7d7e5322466f3c1446b0eac58ab30d1cc29216..d12bffa5f70c317d768304be3470899047cb9c9a 100644 (file)
@@ -297,9 +297,9 @@ int amdgpu_vm_validate_pt_bos(struct amdgpu_device *adev, struct amdgpu_vm *vm,
 
                if (bo->parent) {
                        spin_lock(&glob->lru_lock);
-                       ttm_bo_move_to_lru_tail(&bo->tbo);
+                       ttm_bo_move_to_lru_tail(&bo->tbo, NULL);
                        if (bo->shadow)
-                               ttm_bo_move_to_lru_tail(&bo->shadow->tbo);
+                               ttm_bo_move_to_lru_tail(&bo->shadow->tbo, NULL);
                        spin_unlock(&glob->lru_lock);
                }
 
@@ -319,9 +319,9 @@ int amdgpu_vm_validate_pt_bos(struct amdgpu_device *adev, struct amdgpu_vm *vm,
                if (!bo->parent)
                        continue;
 
-               ttm_bo_move_to_lru_tail(&bo->tbo);
+               ttm_bo_move_to_lru_tail(&bo->tbo, NULL);
                if (bo->shadow)
-                       ttm_bo_move_to_lru_tail(&bo->shadow->tbo);
+                       ttm_bo_move_to_lru_tail(&bo->shadow->tbo, NULL);
        }
        spin_unlock(&glob->lru_lock);
 
index 7c484729f9b21ad9f7bcf99b810261e8b5d8f68b..7117b6b1e22313c4fccb721288dbeb321d9ca362 100644 (file)
@@ -214,12 +214,36 @@ void ttm_bo_del_sub_from_lru(struct ttm_buffer_object *bo)
 }
 EXPORT_SYMBOL(ttm_bo_del_sub_from_lru);
 
-void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo)
+static void ttm_bo_bulk_move_set_pos(struct ttm_lru_bulk_move_pos *pos,
+                                    struct ttm_buffer_object *bo)
+{
+       if (!pos->first)
+               pos->first = bo;
+       pos->last = bo;
+}
+
+void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
+                            struct ttm_lru_bulk_move *bulk)
 {
        reservation_object_assert_held(bo->resv);
 
        ttm_bo_del_from_lru(bo);
        ttm_bo_add_to_lru(bo);
+
+       if (bulk && !(bo->mem.placement & TTM_PL_FLAG_NO_EVICT)) {
+               switch (bo->mem.mem_type) {
+               case TTM_PL_TT:
+                       ttm_bo_bulk_move_set_pos(&bulk->tt[bo->priority], bo);
+                       break;
+
+               case TTM_PL_VRAM:
+                       ttm_bo_bulk_move_set_pos(&bulk->vram[bo->priority], bo);
+                       break;
+               }
+               if (bo->ttm && !(bo->ttm->page_flags &
+                                (TTM_PAGE_FLAG_SG | TTM_PAGE_FLAG_SWAPPED)))
+                       ttm_bo_bulk_move_set_pos(&bulk->swap[bo->priority], bo);
+       }
 }
 EXPORT_SYMBOL(ttm_bo_move_to_lru_tail);
 
index a01ba2032f0ef7042653e08f7563c89518c475ed..0d4eb81423ee67da8f672f33a6dc7482b9e7f769 100644 (file)
@@ -51,6 +51,8 @@ struct ttm_placement;
 
 struct ttm_place;
 
+struct ttm_lru_bulk_move;
+
 /**
  * struct ttm_bus_placement
  *
@@ -405,12 +407,14 @@ void ttm_bo_del_from_lru(struct ttm_buffer_object *bo);
  * ttm_bo_move_to_lru_tail
  *
  * @bo: The buffer object.
+ * @bulk: optional bulk move structure to remember BO positions
  *
  * Move this BO to the tail of all lru lists used to lookup and reserve an
  * object. This function must be called with struct ttm_bo_global::lru_lock
  * held, and is used to make a BO less likely to be considered for eviction.
  */
-void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo);
+void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
+                            struct ttm_lru_bulk_move *bulk);
 
 /**
  * ttm_bo_lock_delayed_workqueue