All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] drm/ttm: device naming cleanup
@ 2021-01-21 11:58 Christian König
  2021-01-21 13:39 ` Daniel Vetter
  2021-01-22  8:27 ` Huang Rui
  0 siblings, 2 replies; 4+ messages in thread
From: Christian König @ 2021-01-21 11:58 UTC (permalink / raw)
  To: dri-devel; +Cc: ray.huang

Rename ttm_bo_device to ttm_device.
Rename ttm_bo_driver to ttm_device_funcs.
Rename ttm_bo_global to ttm_global.

Move global and device related functions to ttm_device.[ch].

No functional change.

Signed-off-by: Christian König <christian.koenig@amd.com>
---
 drivers/gpu/drm/amd/amdgpu/amdgpu.h           |   2 +-
 .../gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c  |   6 +-
 drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c      |   2 +-
 drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c       |  26 +-
 drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h       |   2 +-
 drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c        |   8 +-
 drivers/gpu/drm/drm_gem_vram_helper.c         |  14 +-
 drivers/gpu/drm/nouveau/nouveau_bo.c          |  20 +-
 drivers/gpu/drm/nouveau/nouveau_bo.h          |   2 +-
 drivers/gpu/drm/nouveau/nouveau_drv.h         |   2 +-
 drivers/gpu/drm/nouveau/nouveau_sgdma.c       |   6 +-
 drivers/gpu/drm/nouveau/nouveau_ttm.c         |  10 +-
 drivers/gpu/drm/nouveau/nouveau_ttm.h         |   8 +-
 drivers/gpu/drm/qxl/qxl_drv.h                 |   4 +-
 drivers/gpu/drm/qxl/qxl_release.c             |   6 +-
 drivers/gpu/drm/qxl/qxl_ttm.c                 |  19 +-
 drivers/gpu/drm/radeon/radeon.h               |   6 +-
 drivers/gpu/drm/radeon/radeon_object.c        |   2 +-
 drivers/gpu/drm/radeon/radeon_ttm.c           |  38 +-
 drivers/gpu/drm/ttm/Makefile                  |   2 +-
 drivers/gpu/drm/ttm/ttm_agp_backend.c         |   2 +-
 drivers/gpu/drm/ttm/ttm_bo.c                  | 256 +++-----------
 drivers/gpu/drm/ttm/ttm_bo_util.c             |  24 +-
 drivers/gpu/drm/ttm/ttm_bo_vm.c               |  24 +-
 drivers/gpu/drm/ttm/ttm_device.c              | 195 +++++++++++
 drivers/gpu/drm/ttm/ttm_execbuf_util.c        |   8 +-
 drivers/gpu/drm/ttm/ttm_range_manager.c       |   4 +-
 drivers/gpu/drm/ttm/ttm_resource.c            |   4 +-
 drivers/gpu/drm/ttm/ttm_tt.c                  |  26 +-
 drivers/gpu/drm/vmwgfx/vmwgfx_blit.c          |   4 +-
 drivers/gpu/drm/vmwgfx/vmwgfx_bo.c            |   4 +-
 drivers/gpu/drm/vmwgfx/vmwgfx_drv.c           |  16 +-
 drivers/gpu/drm/vmwgfx/vmwgfx_drv.h           |   4 +-
 drivers/gpu/drm/vmwgfx/vmwgfx_resource.c      |   2 +-
 drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c    |  14 +-
 include/drm/drm_gem_vram_helper.h             |   6 +-
 include/drm/ttm/ttm_bo_api.h                  |  35 +-
 include/drm/ttm/ttm_bo_driver.h               | 328 +-----------------
 include/drm/ttm/ttm_device.h                  | 319 +++++++++++++++++
 include/drm/ttm/ttm_resource.h                |   4 +-
 include/drm/ttm/ttm_tt.h                      |  10 +-
 41 files changed, 759 insertions(+), 715 deletions(-)
 create mode 100644 drivers/gpu/drm/ttm/ttm_device.c
 create mode 100644 include/drm/ttm/ttm_device.h

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu.h b/drivers/gpu/drm/amd/amdgpu/amdgpu.h
index f77443cd9c17..ab4ac3b2651e 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu.h
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu.h
@@ -1053,7 +1053,7 @@ static inline struct drm_device *adev_to_drm(struct amdgpu_device *adev)
 	return &adev->ddev;
 }
 
-static inline struct amdgpu_device *amdgpu_ttm_adev(struct ttm_bo_device *bdev)
+static inline struct amdgpu_device *amdgpu_ttm_adev(struct ttm_device *bdev)
 {
 	return container_of(bdev, struct amdgpu_device, mman.bdev);
 }
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c
index 3107b9575929..5af464933976 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c
@@ -40,13 +40,13 @@ static atomic_t fence_seq = ATOMIC_INIT(0);
  * All the BOs in a process share an eviction fence. When process X wants
  * to map VRAM memory but TTM can't find enough space, TTM will attempt to
  * evict BOs from its LRU list. TTM checks if the BO is valuable to evict
- * by calling ttm_bo_driver->eviction_valuable().
+ * by calling ttm_device_funcs->eviction_valuable().
  *
- * ttm_bo_driver->eviction_valuable() - will return false if the BO belongs
+ * ttm_device_funcs->eviction_valuable() - will return false if the BO belongs
  *  to process X. Otherwise, it will return true to indicate BO can be
  *  evicted by TTM.
  *
- * If ttm_bo_driver->eviction_valuable returns true, then TTM will continue
+ * If ttm_device_funcs->eviction_valuable returns true, then TTM will continue
  * the evcition process for that BO by calling ttm_bo_evict --> amdgpu_bo_move
  * --> amdgpu_copy_buffer(). This sets up job in GPU scheduler.
  *
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c
index 0db933026722..fde2d899b2c4 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c
@@ -71,7 +71,7 @@
  */
 static int amdgpu_gart_dummy_page_init(struct amdgpu_device *adev)
 {
-	struct page *dummy_page = ttm_bo_glob.dummy_read_page;
+	struct page *dummy_page = ttm_glob.dummy_read_page;
 
 	if (adev->dummy_page_addr)
 		return 0;
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
index 9fd2157b133a..29cfb0809634 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
@@ -61,10 +61,10 @@
 
 #define AMDGPU_TTM_VRAM_MAX_DW_READ	(size_t)128
 
-static int amdgpu_ttm_backend_bind(struct ttm_bo_device *bdev,
+static int amdgpu_ttm_backend_bind(struct ttm_device *bdev,
 				   struct ttm_tt *ttm,
 				   struct ttm_resource *bo_mem);
-static void amdgpu_ttm_backend_unbind(struct ttm_bo_device *bdev,
+static void amdgpu_ttm_backend_unbind(struct ttm_device *bdev,
 				      struct ttm_tt *ttm);
 
 static int amdgpu_ttm_init_on_chip(struct amdgpu_device *adev,
@@ -646,7 +646,7 @@ static int amdgpu_bo_move(struct ttm_buffer_object *bo, bool evict,
  *
  * Called by ttm_mem_io_reserve() ultimately via ttm_bo_vm_fault()
  */
-static int amdgpu_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *mem)
+static int amdgpu_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *mem)
 {
 	struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
 	struct drm_mm_node *mm_node = mem->mm_node;
@@ -893,7 +893,7 @@ void amdgpu_ttm_tt_set_user_pages(struct ttm_tt *ttm, struct page **pages)
  *
  * Called by amdgpu_ttm_backend_bind()
  **/
-static int amdgpu_ttm_tt_pin_userptr(struct ttm_bo_device *bdev,
+static int amdgpu_ttm_tt_pin_userptr(struct ttm_device *bdev,
 				     struct ttm_tt *ttm)
 {
 	struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
@@ -931,7 +931,7 @@ static int amdgpu_ttm_tt_pin_userptr(struct ttm_bo_device *bdev,
 /*
  * amdgpu_ttm_tt_unpin_userptr - Unpin and unmap userptr pages
  */
-static void amdgpu_ttm_tt_unpin_userptr(struct ttm_bo_device *bdev,
+static void amdgpu_ttm_tt_unpin_userptr(struct ttm_device *bdev,
 					struct ttm_tt *ttm)
 {
 	struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
@@ -1015,7 +1015,7 @@ static int amdgpu_ttm_gart_bind(struct amdgpu_device *adev,
  * Called by ttm_tt_bind() on behalf of ttm_bo_handle_move_mem().
  * This handles binding GTT memory to the device address space.
  */
-static int amdgpu_ttm_backend_bind(struct ttm_bo_device *bdev,
+static int amdgpu_ttm_backend_bind(struct ttm_device *bdev,
 				   struct ttm_tt *ttm,
 				   struct ttm_resource *bo_mem)
 {
@@ -1155,7 +1155,7 @@ int amdgpu_ttm_recover_gart(struct ttm_buffer_object *tbo)
  * Called by ttm_tt_unbind() on behalf of ttm_bo_move_ttm() and
  * ttm_tt_destroy().
  */
-static void amdgpu_ttm_backend_unbind(struct ttm_bo_device *bdev,
+static void amdgpu_ttm_backend_unbind(struct ttm_device *bdev,
 				      struct ttm_tt *ttm)
 {
 	struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
@@ -1180,7 +1180,7 @@ static void amdgpu_ttm_backend_unbind(struct ttm_bo_device *bdev,
 	gtt->bound = false;
 }
 
-static void amdgpu_ttm_backend_destroy(struct ttm_bo_device *bdev,
+static void amdgpu_ttm_backend_destroy(struct ttm_device *bdev,
 				       struct ttm_tt *ttm)
 {
 	struct amdgpu_ttm_tt *gtt = (void *)ttm;
@@ -1234,7 +1234,7 @@ static struct ttm_tt *amdgpu_ttm_tt_create(struct ttm_buffer_object *bo,
  * Map the pages of a ttm_tt object to an address space visible
  * to the underlying device.
  */
-static int amdgpu_ttm_tt_populate(struct ttm_bo_device *bdev,
+static int amdgpu_ttm_tt_populate(struct ttm_device *bdev,
 				  struct ttm_tt *ttm,
 				  struct ttm_operation_ctx *ctx)
 {
@@ -1278,7 +1278,7 @@ static int amdgpu_ttm_tt_populate(struct ttm_bo_device *bdev,
  * Unmaps pages of a ttm_tt object from the device address space and
  * unpopulates the page array backing it.
  */
-static void amdgpu_ttm_tt_unpopulate(struct ttm_bo_device *bdev,
+static void amdgpu_ttm_tt_unpopulate(struct ttm_device *bdev,
 				     struct ttm_tt *ttm)
 {
 	struct amdgpu_ttm_tt *gtt = (void *)ttm;
@@ -1603,7 +1603,7 @@ amdgpu_bo_delete_mem_notify(struct ttm_buffer_object *bo)
 	amdgpu_bo_move_notify(bo, false, NULL);
 }
 
-static struct ttm_bo_driver amdgpu_bo_driver = {
+static struct ttm_device_funcs amdgpu_bo_driver = {
 	.ttm_tt_create = &amdgpu_ttm_tt_create,
 	.ttm_tt_populate = &amdgpu_ttm_tt_populate,
 	.ttm_tt_unpopulate = &amdgpu_ttm_tt_unpopulate,
@@ -1785,7 +1785,7 @@ int amdgpu_ttm_init(struct amdgpu_device *adev)
 	mutex_init(&adev->mman.gtt_window_lock);
 
 	/* No others user of address space so set it to 0 */
-	r = ttm_bo_device_init(&adev->mman.bdev, &amdgpu_bo_driver, adev->dev,
+	r = ttm_device_init(&adev->mman.bdev, &amdgpu_bo_driver, adev->dev,
 			       adev_to_drm(adev)->anon_inode->i_mapping,
 			       adev_to_drm(adev)->vma_offset_manager,
 			       adev->need_swiotlb,
@@ -1926,7 +1926,7 @@ void amdgpu_ttm_fini(struct amdgpu_device *adev)
 	ttm_range_man_fini(&adev->mman.bdev, AMDGPU_PL_GDS);
 	ttm_range_man_fini(&adev->mman.bdev, AMDGPU_PL_GWS);
 	ttm_range_man_fini(&adev->mman.bdev, AMDGPU_PL_OA);
-	ttm_bo_device_release(&adev->mman.bdev);
+	ttm_device_fini(&adev->mman.bdev);
 	adev->mman.initialized = false;
 	DRM_INFO("amdgpu: ttm finalized\n");
 }
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h
index d2987536d7cd..7189f8370108 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h
@@ -60,7 +60,7 @@ struct amdgpu_gtt_mgr {
 };
 
 struct amdgpu_mman {
-	struct ttm_bo_device		bdev;
+	struct ttm_device		bdev;
 	bool				initialized;
 	void __iomem			*aper_base_kaddr;
 
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
index ad91c0c3c423..9d19078246c8 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
@@ -638,15 +638,15 @@ void amdgpu_vm_move_to_lru_tail(struct amdgpu_device *adev,
 	struct amdgpu_vm_bo_base *bo_base;
 
 	if (vm->bulk_moveable) {
-		spin_lock(&ttm_bo_glob.lru_lock);
+		spin_lock(&ttm_glob.lru_lock);
 		ttm_bo_bulk_move_lru_tail(&vm->lru_bulk_move);
-		spin_unlock(&ttm_bo_glob.lru_lock);
+		spin_unlock(&ttm_glob.lru_lock);
 		return;
 	}
 
 	memset(&vm->lru_bulk_move, 0, sizeof(vm->lru_bulk_move));
 
-	spin_lock(&ttm_bo_glob.lru_lock);
+	spin_lock(&ttm_glob.lru_lock);
 	list_for_each_entry(bo_base, &vm->idle, vm_status) {
 		struct amdgpu_bo *bo = bo_base->bo;
 
@@ -660,7 +660,7 @@ void amdgpu_vm_move_to_lru_tail(struct amdgpu_device *adev,
 						&bo->shadow->tbo.mem,
 						&vm->lru_bulk_move);
 	}
-	spin_unlock(&ttm_bo_glob.lru_lock);
+	spin_unlock(&ttm_glob.lru_lock);
 
 	vm->bulk_moveable = true;
 }
diff --git a/drivers/gpu/drm/drm_gem_vram_helper.c b/drivers/gpu/drm/drm_gem_vram_helper.c
index 02ca22e90290..0b13c8507688 100644
--- a/drivers/gpu/drm/drm_gem_vram_helper.c
+++ b/drivers/gpu/drm/drm_gem_vram_helper.c
@@ -187,7 +187,7 @@ struct drm_gem_vram_object *drm_gem_vram_create(struct drm_device *dev,
 	struct drm_gem_vram_object *gbo;
 	struct drm_gem_object *gem;
 	struct drm_vram_mm *vmm = dev->vram_mm;
-	struct ttm_bo_device *bdev;
+	struct ttm_device *bdev;
 	int ret;
 	size_t acc_size;
 
@@ -551,7 +551,7 @@ int drm_gem_vram_fill_create_dumb(struct drm_file *file,
 EXPORT_SYMBOL(drm_gem_vram_fill_create_dumb);
 
 /*
- * Helpers for struct ttm_bo_driver
+ * Helpers for struct ttm_device_funcs
  */
 
 static bool drm_is_gem_vram(struct ttm_buffer_object *bo)
@@ -893,7 +893,7 @@ static const struct drm_gem_object_funcs drm_gem_vram_object_funcs = {
  * TTM TT
  */
 
-static void bo_driver_ttm_tt_destroy(struct ttm_bo_device *bdev, struct ttm_tt *tt)
+static void bo_driver_ttm_tt_destroy(struct ttm_device *bdev, struct ttm_tt *tt)
 {
 	ttm_tt_destroy_common(bdev, tt);
 	ttm_tt_fini(tt);
@@ -965,7 +965,7 @@ static int bo_driver_move(struct ttm_buffer_object *bo,
 	return drm_gem_vram_bo_driver_move(gbo, evict, ctx, new_mem);
 }
 
-static int bo_driver_io_mem_reserve(struct ttm_bo_device *bdev,
+static int bo_driver_io_mem_reserve(struct ttm_device *bdev,
 				    struct ttm_resource *mem)
 {
 	struct drm_vram_mm *vmm = drm_vram_mm_of_bdev(bdev);
@@ -985,7 +985,7 @@ static int bo_driver_io_mem_reserve(struct ttm_bo_device *bdev,
 	return 0;
 }
 
-static struct ttm_bo_driver bo_driver = {
+static struct ttm_device_funcs bo_driver = {
 	.ttm_tt_create = bo_driver_ttm_tt_create,
 	.ttm_tt_destroy = bo_driver_ttm_tt_destroy,
 	.eviction_valuable = ttm_bo_eviction_valuable,
@@ -1036,7 +1036,7 @@ static int drm_vram_mm_init(struct drm_vram_mm *vmm, struct drm_device *dev,
 	vmm->vram_base = vram_base;
 	vmm->vram_size = vram_size;
 
-	ret = ttm_bo_device_init(&vmm->bdev, &bo_driver, dev->dev,
+	ret = ttm_device_init(&vmm->bdev, &bo_driver, dev->dev,
 				 dev->anon_inode->i_mapping,
 				 dev->vma_offset_manager,
 				 false, true);
@@ -1054,7 +1054,7 @@ static int drm_vram_mm_init(struct drm_vram_mm *vmm, struct drm_device *dev,
 static void drm_vram_mm_cleanup(struct drm_vram_mm *vmm)
 {
 	ttm_range_man_fini(&vmm->bdev, TTM_PL_VRAM);
-	ttm_bo_device_release(&vmm->bdev);
+	ttm_device_fini(&vmm->bdev);
 }
 
 /*
diff --git a/drivers/gpu/drm/nouveau/nouveau_bo.c b/drivers/gpu/drm/nouveau/nouveau_bo.c
index 33dc886d1d6d..c177940d6e2c 100644
--- a/drivers/gpu/drm/nouveau/nouveau_bo.c
+++ b/drivers/gpu/drm/nouveau/nouveau_bo.c
@@ -43,9 +43,9 @@
 #include <nvif/if500b.h>
 #include <nvif/if900b.h>
 
-static int nouveau_ttm_tt_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm,
+static int nouveau_ttm_tt_bind(struct ttm_device *bdev, struct ttm_tt *ttm,
 			       struct ttm_resource *reg);
-static void nouveau_ttm_tt_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
+static void nouveau_ttm_tt_unbind(struct ttm_device *bdev, struct ttm_tt *ttm);
 
 /*
  * NV10-NV40 tiling helpers
@@ -674,7 +674,7 @@ nouveau_ttm_tt_create(struct ttm_buffer_object *bo, uint32_t page_flags)
 }
 
 static int
-nouveau_ttm_tt_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm,
+nouveau_ttm_tt_bind(struct ttm_device *bdev, struct ttm_tt *ttm,
 		    struct ttm_resource *reg)
 {
 #if IS_ENABLED(CONFIG_AGP)
@@ -690,7 +690,7 @@ nouveau_ttm_tt_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm,
 }
 
 static void
-nouveau_ttm_tt_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
+nouveau_ttm_tt_unbind(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
 #if IS_ENABLED(CONFIG_AGP)
 	struct nouveau_drm *drm = nouveau_bdev(bdev);
@@ -1055,7 +1055,7 @@ nouveau_ttm_io_mem_free_locked(struct nouveau_drm *drm,
 }
 
 static int
-nouveau_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *reg)
+nouveau_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *reg)
 {
 	struct nouveau_drm *drm = nouveau_bdev(bdev);
 	struct nvkm_device *device = nvxx_device(&drm->client.device);
@@ -1163,7 +1163,7 @@ nouveau_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *reg)
 }
 
 static void
-nouveau_ttm_io_mem_free(struct ttm_bo_device *bdev, struct ttm_resource *reg)
+nouveau_ttm_io_mem_free(struct ttm_device *bdev, struct ttm_resource *reg)
 {
 	struct nouveau_drm *drm = nouveau_bdev(bdev);
 
@@ -1223,7 +1223,7 @@ vm_fault_t nouveau_ttm_fault_reserve_notify(struct ttm_buffer_object *bo)
 }
 
 static int
-nouveau_ttm_tt_populate(struct ttm_bo_device *bdev,
+nouveau_ttm_tt_populate(struct ttm_device *bdev,
 			struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)
 {
 	struct ttm_tt *ttm_dma = (void *)ttm;
@@ -1247,7 +1247,7 @@ nouveau_ttm_tt_populate(struct ttm_bo_device *bdev,
 }
 
 static void
-nouveau_ttm_tt_unpopulate(struct ttm_bo_device *bdev,
+nouveau_ttm_tt_unpopulate(struct ttm_device *bdev,
 			  struct ttm_tt *ttm)
 {
 	struct nouveau_drm *drm;
@@ -1264,7 +1264,7 @@ nouveau_ttm_tt_unpopulate(struct ttm_bo_device *bdev,
 }
 
 static void
-nouveau_ttm_tt_destroy(struct ttm_bo_device *bdev,
+nouveau_ttm_tt_destroy(struct ttm_device *bdev,
 		       struct ttm_tt *ttm)
 {
 #if IS_ENABLED(CONFIG_AGP)
@@ -1296,7 +1296,7 @@ nouveau_bo_delete_mem_notify(struct ttm_buffer_object *bo)
 	nouveau_bo_move_ntfy(bo, false, NULL);
 }
 
-struct ttm_bo_driver nouveau_bo_driver = {
+struct ttm_device_funcs nouveau_bo_driver = {
 	.ttm_tt_create = &nouveau_ttm_tt_create,
 	.ttm_tt_populate = &nouveau_ttm_tt_populate,
 	.ttm_tt_unpopulate = &nouveau_ttm_tt_unpopulate,
diff --git a/drivers/gpu/drm/nouveau/nouveau_bo.h b/drivers/gpu/drm/nouveau/nouveau_bo.h
index 6045b85a762a..c2d3f9c48eba 100644
--- a/drivers/gpu/drm/nouveau/nouveau_bo.h
+++ b/drivers/gpu/drm/nouveau/nouveau_bo.h
@@ -68,7 +68,7 @@ nouveau_bo_ref(struct nouveau_bo *ref, struct nouveau_bo **pnvbo)
 	return 0;
 }
 
-extern struct ttm_bo_driver nouveau_bo_driver;
+extern struct ttm_device_funcs nouveau_bo_driver;
 
 void nouveau_bo_move_init(struct nouveau_drm *);
 struct nouveau_bo *nouveau_bo_alloc(struct nouveau_cli *, u64 *size, int *align,
diff --git a/drivers/gpu/drm/nouveau/nouveau_drv.h b/drivers/gpu/drm/nouveau/nouveau_drv.h
index c802d3d1ba39..edf9d1ee9d58 100644
--- a/drivers/gpu/drm/nouveau/nouveau_drv.h
+++ b/drivers/gpu/drm/nouveau/nouveau_drv.h
@@ -151,7 +151,7 @@ struct nouveau_drm {
 
 	/* TTM interface support */
 	struct {
-		struct ttm_bo_device bdev;
+		struct ttm_device bdev;
 		atomic_t validate_sequence;
 		int (*move)(struct nouveau_channel *,
 			    struct ttm_buffer_object *,
diff --git a/drivers/gpu/drm/nouveau/nouveau_sgdma.c b/drivers/gpu/drm/nouveau/nouveau_sgdma.c
index 1cf52635ea74..256ec5b35473 100644
--- a/drivers/gpu/drm/nouveau/nouveau_sgdma.c
+++ b/drivers/gpu/drm/nouveau/nouveau_sgdma.c
@@ -16,7 +16,7 @@ struct nouveau_sgdma_be {
 };
 
 void
-nouveau_sgdma_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
+nouveau_sgdma_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
 	struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm;
 
@@ -29,7 +29,7 @@ nouveau_sgdma_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
 }
 
 int
-nouveau_sgdma_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg)
+nouveau_sgdma_bind(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg)
 {
 	struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm;
 	struct nouveau_drm *drm = nouveau_bdev(bdev);
@@ -56,7 +56,7 @@ nouveau_sgdma_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_re
 }
 
 void
-nouveau_sgdma_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
+nouveau_sgdma_unbind(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
 	struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm;
 	if (nvbe->mem) {
diff --git a/drivers/gpu/drm/nouveau/nouveau_ttm.c b/drivers/gpu/drm/nouveau/nouveau_ttm.c
index a37bc3d7b38b..495288182c2d 100644
--- a/drivers/gpu/drm/nouveau/nouveau_ttm.c
+++ b/drivers/gpu/drm/nouveau/nouveau_ttm.c
@@ -324,10 +324,10 @@ nouveau_ttm_init(struct nouveau_drm *drm)
 	need_swiotlb = !!swiotlb_nr_tbl();
 #endif
 
-	ret = ttm_bo_device_init(&drm->ttm.bdev, &nouveau_bo_driver,
-				 drm->dev->dev, dev->anon_inode->i_mapping,
-				 dev->vma_offset_manager, need_swiotlb,
-				 drm->client.mmu.dmabits <= 32);
+	ret = ttm_device_init(&drm->ttm.bdev, &nouveau_bo_driver, drm->dev->dev,
+				  dev->anon_inode->i_mapping,
+				  dev->vma_offset_manager, need_swiotlb,
+				  drm->client.mmu.dmabits <= 32);
 	if (ret) {
 		NV_ERROR(drm, "error initialising bo driver, %d\n", ret);
 		return ret;
@@ -377,7 +377,7 @@ nouveau_ttm_fini(struct nouveau_drm *drm)
 	nouveau_ttm_fini_vram(drm);
 	nouveau_ttm_fini_gtt(drm);
 
-	ttm_bo_device_release(&drm->ttm.bdev);
+	ttm_device_fini(&drm->ttm.bdev);
 
 	arch_phys_wc_del(drm->ttm.mtrr);
 	drm->ttm.mtrr = 0;
diff --git a/drivers/gpu/drm/nouveau/nouveau_ttm.h b/drivers/gpu/drm/nouveau/nouveau_ttm.h
index 69552049bb96..dbf6dc238efd 100644
--- a/drivers/gpu/drm/nouveau/nouveau_ttm.h
+++ b/drivers/gpu/drm/nouveau/nouveau_ttm.h
@@ -3,7 +3,7 @@
 #define __NOUVEAU_TTM_H__
 
 static inline struct nouveau_drm *
-nouveau_bdev(struct ttm_bo_device *bd)
+nouveau_bdev(struct ttm_device *bd)
 {
 	return container_of(bd, struct nouveau_drm, ttm.bdev);
 }
@@ -22,7 +22,7 @@ int  nouveau_ttm_mmap(struct file *, struct vm_area_struct *);
 int  nouveau_ttm_global_init(struct nouveau_drm *);
 void nouveau_ttm_global_release(struct nouveau_drm *);
 
-int nouveau_sgdma_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg);
-void nouveau_sgdma_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
-void nouveau_sgdma_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
+int nouveau_sgdma_bind(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg);
+void nouveau_sgdma_unbind(struct ttm_device *bdev, struct ttm_tt *ttm);
+void nouveau_sgdma_destroy(struct ttm_device *bdev, struct ttm_tt *ttm);
 #endif
diff --git a/drivers/gpu/drm/qxl/qxl_drv.h b/drivers/gpu/drm/qxl/qxl_drv.h
index 83b54f0dad61..01354b43c413 100644
--- a/drivers/gpu/drm/qxl/qxl_drv.h
+++ b/drivers/gpu/drm/qxl/qxl_drv.h
@@ -125,7 +125,7 @@ struct qxl_output {
 #define drm_encoder_to_qxl_output(x) container_of(x, struct qxl_output, enc)
 
 struct qxl_mman {
-	struct ttm_bo_device		bdev;
+	struct ttm_device		bdev;
 };
 
 struct qxl_memslot {
@@ -335,7 +335,7 @@ int qxl_mode_dumb_mmap(struct drm_file *filp,
 /* qxl ttm */
 int qxl_ttm_init(struct qxl_device *qdev);
 void qxl_ttm_fini(struct qxl_device *qdev);
-int qxl_ttm_io_mem_reserve(struct ttm_bo_device *bdev,
+int qxl_ttm_io_mem_reserve(struct ttm_device *bdev,
 			   struct ttm_resource *mem);
 
 /* qxl image */
diff --git a/drivers/gpu/drm/qxl/qxl_release.c b/drivers/gpu/drm/qxl/qxl_release.c
index 0fcfc952d5e9..c52412724c26 100644
--- a/drivers/gpu/drm/qxl/qxl_release.c
+++ b/drivers/gpu/drm/qxl/qxl_release.c
@@ -429,7 +429,7 @@ void qxl_release_unmap(struct qxl_device *qdev,
 void qxl_release_fence_buffer_objects(struct qxl_release *release)
 {
 	struct ttm_buffer_object *bo;
-	struct ttm_bo_device *bdev;
+	struct ttm_device *bdev;
 	struct ttm_validate_buffer *entry;
 	struct qxl_device *qdev;
 
@@ -450,7 +450,7 @@ void qxl_release_fence_buffer_objects(struct qxl_release *release)
 		       release->id | 0xf0000000, release->base.seqno);
 	trace_dma_fence_emit(&release->base);
 
-	spin_lock(&ttm_bo_glob.lru_lock);
+	spin_lock(&ttm_glob.lru_lock);
 
 	list_for_each_entry(entry, &release->bos, head) {
 		bo = entry->bo;
@@ -459,7 +459,7 @@ void qxl_release_fence_buffer_objects(struct qxl_release *release)
 		ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
 		dma_resv_unlock(bo->base.resv);
 	}
-	spin_unlock(&ttm_bo_glob.lru_lock);
+	spin_unlock(&ttm_glob.lru_lock);
 	ww_acquire_fini(&release->ticket);
 }
 
diff --git a/drivers/gpu/drm/qxl/qxl_ttm.c b/drivers/gpu/drm/qxl/qxl_ttm.c
index 33c09dc94f8b..b7f77eb685cb 100644
--- a/drivers/gpu/drm/qxl/qxl_ttm.c
+++ b/drivers/gpu/drm/qxl/qxl_ttm.c
@@ -36,7 +36,7 @@
 #include "qxl_drv.h"
 #include "qxl_object.h"
 
-static struct qxl_device *qxl_get_qdev(struct ttm_bo_device *bdev)
+static struct qxl_device *qxl_get_qdev(struct ttm_device *bdev)
 {
 	struct qxl_mman *mman;
 	struct qxl_device *qdev;
@@ -69,7 +69,7 @@ static void qxl_evict_flags(struct ttm_buffer_object *bo,
 	*placement = qbo->placement;
 }
 
-int qxl_ttm_io_mem_reserve(struct ttm_bo_device *bdev,
+int qxl_ttm_io_mem_reserve(struct ttm_device *bdev,
 			   struct ttm_resource *mem)
 {
 	struct qxl_device *qdev = qxl_get_qdev(bdev);
@@ -98,8 +98,7 @@ int qxl_ttm_io_mem_reserve(struct ttm_bo_device *bdev,
 /*
  * TTM backend functions.
  */
-static void qxl_ttm_backend_destroy(struct ttm_bo_device *bdev,
-				    struct ttm_tt *ttm)
+static void qxl_ttm_backend_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
 	ttm_tt_destroy_common(bdev, ttm);
 	ttm_tt_fini(ttm);
@@ -170,7 +169,7 @@ static void qxl_bo_delete_mem_notify(struct ttm_buffer_object *bo)
 	qxl_bo_move_notify(bo, false, NULL);
 }
 
-static struct ttm_bo_driver qxl_bo_driver = {
+static struct ttm_device_funcs qxl_bo_driver = {
 	.ttm_tt_create = &qxl_ttm_tt_create,
 	.ttm_tt_destroy = &qxl_ttm_backend_destroy,
 	.eviction_valuable = ttm_bo_eviction_valuable,
@@ -193,10 +192,10 @@ int qxl_ttm_init(struct qxl_device *qdev)
 	int num_io_pages; /* != rom->num_io_pages, we include surface0 */
 
 	/* No others user of address space so set it to 0 */
-	r = ttm_bo_device_init(&qdev->mman.bdev, &qxl_bo_driver, NULL,
-			       qdev->ddev.anon_inode->i_mapping,
-			       qdev->ddev.vma_offset_manager,
-			       false, false);
+	r = ttm_device_init(&qdev->mman.bdev, &qxl_bo_driver, NULL,
+			    qdev->ddev.anon_inode->i_mapping,
+			    qdev->ddev.vma_offset_manager,
+			    false, false);
 	if (r) {
 		DRM_ERROR("failed initializing buffer object driver(%d).\n", r);
 		return r;
@@ -227,7 +226,7 @@ void qxl_ttm_fini(struct qxl_device *qdev)
 {
 	ttm_range_man_fini(&qdev->mman.bdev, TTM_PL_VRAM);
 	ttm_range_man_fini(&qdev->mman.bdev, TTM_PL_PRIV);
-	ttm_bo_device_release(&qdev->mman.bdev);
+	ttm_device_fini(&qdev->mman.bdev);
 	DRM_INFO("qxl: ttm finalized\n");
 }
 
diff --git a/drivers/gpu/drm/radeon/radeon.h b/drivers/gpu/drm/radeon/radeon.h
index f09989bdce98..449ba0095ed9 100644
--- a/drivers/gpu/drm/radeon/radeon.h
+++ b/drivers/gpu/drm/radeon/radeon.h
@@ -451,7 +451,7 @@ struct radeon_surface_reg {
  * TTM.
  */
 struct radeon_mman {
-	struct ttm_bo_device		bdev;
+	struct ttm_device		bdev;
 	bool				initialized;
 
 #if defined(CONFIG_DEBUG_FS)
@@ -2822,7 +2822,7 @@ extern int radeon_ttm_tt_set_userptr(struct radeon_device *rdev,
 				     uint32_t flags);
 extern bool radeon_ttm_tt_has_userptr(struct radeon_device *rdev, struct ttm_tt *ttm);
 extern bool radeon_ttm_tt_is_readonly(struct radeon_device *rdev, struct ttm_tt *ttm);
-bool radeon_ttm_tt_is_bound(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
+bool radeon_ttm_tt_is_bound(struct ttm_device *bdev, struct ttm_tt *ttm);
 extern void radeon_vram_location(struct radeon_device *rdev, struct radeon_mc *mc, u64 base);
 extern void radeon_gtt_location(struct radeon_device *rdev, struct radeon_mc *mc);
 extern int radeon_resume_kms(struct drm_device *dev, bool resume, bool fbcon);
@@ -2832,7 +2832,7 @@ extern void radeon_ttm_set_active_vram_size(struct radeon_device *rdev, u64 size
 extern void radeon_program_register_sequence(struct radeon_device *rdev,
 					     const u32 *registers,
 					     const u32 array_size);
-struct radeon_device *radeon_get_rdev(struct ttm_bo_device *bdev);
+struct radeon_device *radeon_get_rdev(struct ttm_device *bdev);
 
 /* KMS */
 
diff --git a/drivers/gpu/drm/radeon/radeon_object.c b/drivers/gpu/drm/radeon/radeon_object.c
index 9b81786782de..6a336284466f 100644
--- a/drivers/gpu/drm/radeon/radeon_object.c
+++ b/drivers/gpu/drm/radeon/radeon_object.c
@@ -372,7 +372,7 @@ void radeon_bo_unpin(struct radeon_bo *bo)
 
 int radeon_bo_evict_vram(struct radeon_device *rdev)
 {
-	struct ttm_bo_device *bdev = &rdev->mman.bdev;
+	struct ttm_device *bdev = &rdev->mman.bdev;
 	struct ttm_resource_manager *man;
 
 	/* late 2.6.33 fix IGP hibernate - we need pm ops to do this correct */
diff --git a/drivers/gpu/drm/radeon/radeon_ttm.c b/drivers/gpu/drm/radeon/radeon_ttm.c
index c6d575f50c48..5ed6a48246d6 100644
--- a/drivers/gpu/drm/radeon/radeon_ttm.c
+++ b/drivers/gpu/drm/radeon/radeon_ttm.c
@@ -55,13 +55,11 @@
 static int radeon_ttm_debugfs_init(struct radeon_device *rdev);
 static void radeon_ttm_debugfs_fini(struct radeon_device *rdev);
 
-static int radeon_ttm_tt_bind(struct ttm_bo_device *bdev,
-			      struct ttm_tt *ttm,
+static int radeon_ttm_tt_bind(struct ttm_device *bdev, struct ttm_tt *ttm,
 			      struct ttm_resource *bo_mem);
-static void radeon_ttm_tt_unbind(struct ttm_bo_device *bdev,
-				 struct ttm_tt *ttm);
+static void radeon_ttm_tt_unbind(struct ttm_device *bdev, struct ttm_tt *ttm);
 
-struct radeon_device *radeon_get_rdev(struct ttm_bo_device *bdev)
+struct radeon_device *radeon_get_rdev(struct ttm_device *bdev)
 {
 	struct radeon_mman *mman;
 	struct radeon_device *rdev;
@@ -280,7 +278,7 @@ static int radeon_bo_move(struct ttm_buffer_object *bo, bool evict,
 	return 0;
 }
 
-static int radeon_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *mem)
+static int radeon_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *mem)
 {
 	struct radeon_device *rdev = radeon_get_rdev(bdev);
 	size_t bus_size = (size_t)mem->num_pages << PAGE_SHIFT;
@@ -347,7 +345,7 @@ struct radeon_ttm_tt {
 };
 
 /* prepare the sg table with the user pages */
-static int radeon_ttm_tt_pin_userptr(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
+static int radeon_ttm_tt_pin_userptr(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
 	struct radeon_device *rdev = radeon_get_rdev(bdev);
 	struct radeon_ttm_tt *gtt = (void *)ttm;
@@ -408,7 +406,7 @@ static int radeon_ttm_tt_pin_userptr(struct ttm_bo_device *bdev, struct ttm_tt *
 	return r;
 }
 
-static void radeon_ttm_tt_unpin_userptr(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
+static void radeon_ttm_tt_unpin_userptr(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
 	struct radeon_device *rdev = radeon_get_rdev(bdev);
 	struct radeon_ttm_tt *gtt = (void *)ttm;
@@ -444,7 +442,7 @@ static bool radeon_ttm_backend_is_bound(struct ttm_tt *ttm)
 	return (gtt->bound);
 }
 
-static int radeon_ttm_backend_bind(struct ttm_bo_device *bdev,
+static int radeon_ttm_backend_bind(struct ttm_device *bdev,
 				   struct ttm_tt *ttm,
 				   struct ttm_resource *bo_mem)
 {
@@ -480,7 +478,7 @@ static int radeon_ttm_backend_bind(struct ttm_bo_device *bdev,
 	return 0;
 }
 
-static void radeon_ttm_backend_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
+static void radeon_ttm_backend_unbind(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
 	struct radeon_ttm_tt *gtt = (void *)ttm;
 	struct radeon_device *rdev = radeon_get_rdev(bdev);
@@ -495,7 +493,7 @@ static void radeon_ttm_backend_unbind(struct ttm_bo_device *bdev, struct ttm_tt
 	gtt->bound = false;
 }
 
-static void radeon_ttm_backend_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
+static void radeon_ttm_backend_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
 	struct radeon_ttm_tt *gtt = (void *)ttm;
 
@@ -554,7 +552,7 @@ static struct radeon_ttm_tt *radeon_ttm_tt_to_gtt(struct radeon_device *rdev,
 	return container_of(ttm, struct radeon_ttm_tt, ttm);
 }
 
-static int radeon_ttm_tt_populate(struct ttm_bo_device *bdev,
+static int radeon_ttm_tt_populate(struct ttm_device *bdev,
 				  struct ttm_tt *ttm,
 				  struct ttm_operation_ctx *ctx)
 {
@@ -580,7 +578,7 @@ static int radeon_ttm_tt_populate(struct ttm_bo_device *bdev,
 	return ttm_pool_alloc(&rdev->mman.bdev.pool, ttm, ctx);
 }
 
-static void radeon_ttm_tt_unpopulate(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
+static void radeon_ttm_tt_unpopulate(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
 	struct radeon_device *rdev = radeon_get_rdev(bdev);
 	struct radeon_ttm_tt *gtt = radeon_ttm_tt_to_gtt(rdev, ttm);
@@ -613,7 +611,7 @@ int radeon_ttm_tt_set_userptr(struct radeon_device *rdev,
 	return 0;
 }
 
-bool radeon_ttm_tt_is_bound(struct ttm_bo_device *bdev,
+bool radeon_ttm_tt_is_bound(struct ttm_device *bdev,
 			    struct ttm_tt *ttm)
 {
 #if IS_ENABLED(CONFIG_AGP)
@@ -624,7 +622,7 @@ bool radeon_ttm_tt_is_bound(struct ttm_bo_device *bdev,
 	return radeon_ttm_backend_is_bound(ttm);
 }
 
-static int radeon_ttm_tt_bind(struct ttm_bo_device *bdev,
+static int radeon_ttm_tt_bind(struct ttm_device *bdev,
 			      struct ttm_tt *ttm,
 			      struct ttm_resource *bo_mem)
 {
@@ -642,7 +640,7 @@ static int radeon_ttm_tt_bind(struct ttm_bo_device *bdev,
 	return radeon_ttm_backend_bind(bdev, ttm, bo_mem);
 }
 
-static void radeon_ttm_tt_unbind(struct ttm_bo_device *bdev,
+static void radeon_ttm_tt_unbind(struct ttm_device *bdev,
 				 struct ttm_tt *ttm)
 {
 #if IS_ENABLED(CONFIG_AGP)
@@ -656,7 +654,7 @@ static void radeon_ttm_tt_unbind(struct ttm_bo_device *bdev,
 	radeon_ttm_backend_unbind(bdev, ttm);
 }
 
-static void radeon_ttm_tt_destroy(struct ttm_bo_device *bdev,
+static void radeon_ttm_tt_destroy(struct ttm_device *bdev,
 				  struct ttm_tt *ttm)
 {
 #if IS_ENABLED(CONFIG_AGP)
@@ -700,7 +698,7 @@ radeon_bo_delete_mem_notify(struct ttm_buffer_object *bo)
 	radeon_bo_move_notify(bo, false, NULL);
 }
 
-static struct ttm_bo_driver radeon_bo_driver = {
+static struct ttm_device_funcs radeon_bo_driver = {
 	.ttm_tt_create = &radeon_ttm_tt_create,
 	.ttm_tt_populate = &radeon_ttm_tt_populate,
 	.ttm_tt_unpopulate = &radeon_ttm_tt_unpopulate,
@@ -718,7 +716,7 @@ int radeon_ttm_init(struct radeon_device *rdev)
 	int r;
 
 	/* No others user of address space so set it to 0 */
-	r = ttm_bo_device_init(&rdev->mman.bdev, &radeon_bo_driver, rdev->dev,
+	r = ttm_device_init(&rdev->mman.bdev, &radeon_bo_driver, rdev->dev,
 			       rdev->ddev->anon_inode->i_mapping,
 			       rdev->ddev->vma_offset_manager,
 			       rdev->need_swiotlb,
@@ -791,7 +789,7 @@ void radeon_ttm_fini(struct radeon_device *rdev)
 	}
 	ttm_range_man_fini(&rdev->mman.bdev, TTM_PL_VRAM);
 	ttm_range_man_fini(&rdev->mman.bdev, TTM_PL_TT);
-	ttm_bo_device_release(&rdev->mman.bdev);
+	ttm_device_fini(&rdev->mman.bdev);
 	radeon_gart_fini(rdev);
 	rdev->mman.initialized = false;
 	DRM_INFO("radeon: ttm finalized\n");
diff --git a/drivers/gpu/drm/ttm/Makefile b/drivers/gpu/drm/ttm/Makefile
index b6f5f87b270f..8e6437eadabe 100644
--- a/drivers/gpu/drm/ttm/Makefile
+++ b/drivers/gpu/drm/ttm/Makefile
@@ -5,7 +5,7 @@
 ttm-y := ttm_memory.o ttm_tt.o ttm_bo.o \
 	ttm_bo_util.o ttm_bo_vm.o ttm_module.o \
 	ttm_execbuf_util.o ttm_range_manager.o \
-	ttm_resource.o ttm_pool.o
+	ttm_resource.o ttm_pool.o ttm_device.o
 ttm-$(CONFIG_AGP) += ttm_agp_backend.o
 
 obj-$(CONFIG_DRM_TTM) += ttm.o
diff --git a/drivers/gpu/drm/ttm/ttm_agp_backend.c b/drivers/gpu/drm/ttm/ttm_agp_backend.c
index 8f9fa4188897..0226ae69d3ab 100644
--- a/drivers/gpu/drm/ttm/ttm_agp_backend.c
+++ b/drivers/gpu/drm/ttm/ttm_agp_backend.c
@@ -49,7 +49,7 @@ struct ttm_agp_backend {
 int ttm_agp_bind(struct ttm_tt *ttm, struct ttm_resource *bo_mem)
 {
 	struct ttm_agp_backend *agp_be = container_of(ttm, struct ttm_agp_backend, ttm);
-	struct page *dummy_read_page = ttm_bo_glob.dummy_read_page;
+	struct page *dummy_read_page = ttm_glob.dummy_read_page;
 	struct drm_mm_node *node = bo_mem->mm_node;
 	struct agp_memory *mem;
 	int ret, cached = ttm->caching == ttm_cached;
diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c
index c289a6a37ff9..20256797f3a6 100644
--- a/drivers/gpu/drm/ttm/ttm_bo.c
+++ b/drivers/gpu/drm/ttm/ttm_bo.c
@@ -44,14 +44,6 @@
 
 #include "ttm_module.h"
 
-/*
- * ttm_global_mutex - protecting the global BO state
- */
-DEFINE_MUTEX(ttm_global_mutex);
-unsigned ttm_bo_glob_use_count;
-struct ttm_bo_global ttm_bo_glob;
-EXPORT_SYMBOL(ttm_bo_glob);
-
 /* default destructor */
 static void ttm_bo_default_destroy(struct ttm_buffer_object *bo)
 {
@@ -79,13 +71,13 @@ static void ttm_bo_mem_space_debug(struct ttm_buffer_object *bo,
 
 static void ttm_bo_del_from_lru(struct ttm_buffer_object *bo)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 
 	list_del_init(&bo->swap);
 	list_del_init(&bo->lru);
 
-	if (bdev->driver->del_from_lru_notify)
-		bdev->driver->del_from_lru_notify(bo);
+	if (bdev->funcs->del_from_lru_notify)
+		bdev->funcs->del_from_lru_notify(bo);
 }
 
 static void ttm_bo_bulk_move_set_pos(struct ttm_lru_bulk_move_pos *pos,
@@ -100,7 +92,7 @@ void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
 			     struct ttm_resource *mem,
 			     struct ttm_lru_bulk_move *bulk)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 	struct ttm_resource_manager *man;
 
 	dma_resv_assert_held(bo->base.resv);
@@ -117,12 +109,12 @@ void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
 				     TTM_PAGE_FLAG_SWAPPED))) {
 		struct list_head *swap;
 
-		swap = &ttm_bo_glob.swap_lru[bo->priority];
+		swap = &ttm_glob.swap_lru[bo->priority];
 		list_move_tail(&bo->swap, swap);
 	}
 
-	if (bdev->driver->del_from_lru_notify)
-		bdev->driver->del_from_lru_notify(bo);
+	if (bdev->funcs->del_from_lru_notify)
+		bdev->funcs->del_from_lru_notify(bo);
 
 	if (bulk && !bo->pin_count) {
 		switch (bo->mem.mem_type) {
@@ -185,7 +177,7 @@ void ttm_bo_bulk_move_lru_tail(struct ttm_lru_bulk_move *bulk)
 		dma_resv_assert_held(pos->first->base.resv);
 		dma_resv_assert_held(pos->last->base.resv);
 
-		lru = &ttm_bo_glob.swap_lru[i];
+		lru = &ttm_glob.swap_lru[i];
 		list_bulk_move_tail(lru, &pos->first->swap, &pos->last->swap);
 	}
 }
@@ -196,7 +188,7 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
 				  struct ttm_operation_ctx *ctx,
 				  struct ttm_place *hop)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 	struct ttm_resource_manager *old_man = ttm_manager_type(bdev, bo->mem.mem_type);
 	struct ttm_resource_manager *new_man = ttm_manager_type(bdev, mem->mem_type);
 	int ret;
@@ -222,7 +214,7 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
 		}
 	}
 
-	ret = bdev->driver->move(bo, evict, ctx, mem, hop);
+	ret = bdev->funcs->move(bo, evict, ctx, mem, hop);
 	if (ret) {
 		if (ret == -EMULTIHOP)
 			return ret;
@@ -250,8 +242,8 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
 
 static void ttm_bo_cleanup_memtype_use(struct ttm_buffer_object *bo)
 {
-	if (bo->bdev->driver->delete_mem_notify)
-		bo->bdev->driver->delete_mem_notify(bo);
+	if (bo->bdev->funcs->delete_mem_notify)
+		bo->bdev->funcs->delete_mem_notify(bo);
 
 	ttm_bo_tt_destroy(bo);
 	ttm_resource_free(bo, &bo->mem);
@@ -276,9 +268,9 @@ static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
 		 * 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);
+		spin_lock(&ttm_glob.lru_lock);
 		bo->base.resv = &bo->base._resv;
-		spin_unlock(&ttm_bo_glob.lru_lock);
+		spin_unlock(&ttm_glob.lru_lock);
 	}
 
 	return r;
@@ -337,7 +329,7 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
 
 		if (unlock_resv)
 			dma_resv_unlock(bo->base.resv);
-		spin_unlock(&ttm_bo_glob.lru_lock);
+		spin_unlock(&ttm_glob.lru_lock);
 
 		lret = dma_resv_wait_timeout_rcu(resv, true, interruptible,
 						 30 * HZ);
@@ -347,7 +339,7 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
 		else if (lret == 0)
 			return -EBUSY;
 
-		spin_lock(&ttm_bo_glob.lru_lock);
+		spin_lock(&ttm_glob.lru_lock);
 		if (unlock_resv && !dma_resv_trylock(bo->base.resv)) {
 			/*
 			 * We raced, and lost, someone else holds the reservation now,
@@ -357,7 +349,7 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
 			 * delayed destruction would succeed, so just return success
 			 * here.
 			 */
-			spin_unlock(&ttm_bo_glob.lru_lock);
+			spin_unlock(&ttm_glob.lru_lock);
 			return 0;
 		}
 		ret = 0;
@@ -366,13 +358,13 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
 	if (ret || unlikely(list_empty(&bo->ddestroy))) {
 		if (unlock_resv)
 			dma_resv_unlock(bo->base.resv);
-		spin_unlock(&ttm_bo_glob.lru_lock);
+		spin_unlock(&ttm_glob.lru_lock);
 		return ret;
 	}
 
 	ttm_bo_del_from_lru(bo);
 	list_del_init(&bo->ddestroy);
-	spin_unlock(&ttm_bo_glob.lru_lock);
+	spin_unlock(&ttm_glob.lru_lock);
 	ttm_bo_cleanup_memtype_use(bo);
 
 	if (unlock_resv)
@@ -387,9 +379,9 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
  * Traverse the delayed list, and call ttm_bo_cleanup_refs on all
  * encountered buffers.
  */
-static bool ttm_bo_delayed_delete(struct ttm_bo_device *bdev, bool remove_all)
+bool ttm_bo_delayed_delete(struct ttm_device *bdev, bool remove_all)
 {
-	struct ttm_bo_global *glob = &ttm_bo_glob;
+	struct ttm_global *glob = &ttm_glob;
 	struct list_head removed;
 	bool empty;
 
@@ -428,21 +420,11 @@ static bool ttm_bo_delayed_delete(struct ttm_bo_device *bdev, bool remove_all)
 	return empty;
 }
 
-static void ttm_bo_delayed_workqueue(struct work_struct *work)
-{
-	struct ttm_bo_device *bdev =
-	    container_of(work, struct ttm_bo_device, wq.work);
-
-	if (!ttm_bo_delayed_delete(bdev, false))
-		schedule_delayed_work(&bdev->wq,
-				      ((HZ / 100) < 1) ? 1 : HZ / 100);
-}
-
 static void ttm_bo_release(struct kref *kref)
 {
 	struct ttm_buffer_object *bo =
 	    container_of(kref, struct ttm_buffer_object, kref);
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 	size_t acc_size = bo->acc_size;
 	int ret;
 
@@ -456,8 +438,8 @@ static void ttm_bo_release(struct kref *kref)
 						  30 * HZ);
 		}
 
-		if (bo->bdev->driver->release_notify)
-			bo->bdev->driver->release_notify(bo);
+		if (bo->bdev->funcs->release_notify)
+			bo->bdev->funcs->release_notify(bo);
 
 		drm_vma_offset_remove(bdev->vma_manager, &bo->base.vma_node);
 		ttm_mem_io_free(bdev, &bo->mem);
@@ -469,7 +451,7 @@ static void ttm_bo_release(struct kref *kref)
 		ttm_bo_flush_all_fences(bo);
 		bo->deleted = true;
 
-		spin_lock(&ttm_bo_glob.lru_lock);
+		spin_lock(&ttm_glob.lru_lock);
 
 		/*
 		 * Make pinned bos immediately available to
@@ -483,22 +465,22 @@ static void ttm_bo_release(struct kref *kref)
 
 		kref_init(&bo->kref);
 		list_add_tail(&bo->ddestroy, &bdev->ddestroy);
-		spin_unlock(&ttm_bo_glob.lru_lock);
+		spin_unlock(&ttm_glob.lru_lock);
 
 		schedule_delayed_work(&bdev->wq,
 				      ((HZ / 100) < 1) ? 1 : HZ / 100);
 		return;
 	}
 
-	spin_lock(&ttm_bo_glob.lru_lock);
+	spin_lock(&ttm_glob.lru_lock);
 	ttm_bo_del_from_lru(bo);
 	list_del(&bo->ddestroy);
-	spin_unlock(&ttm_bo_glob.lru_lock);
+	spin_unlock(&ttm_glob.lru_lock);
 
 	ttm_bo_cleanup_memtype_use(bo);
 	dma_resv_unlock(bo->base.resv);
 
-	atomic_dec(&ttm_bo_glob.bo_count);
+	atomic_dec(&ttm_glob.bo_count);
 	dma_fence_put(bo->moving);
 	if (!ttm_bo_uses_embedded_gem_object(bo))
 		dma_resv_fini(&bo->base._resv);
@@ -512,13 +494,13 @@ void ttm_bo_put(struct ttm_buffer_object *bo)
 }
 EXPORT_SYMBOL(ttm_bo_put);
 
-int ttm_bo_lock_delayed_workqueue(struct ttm_bo_device *bdev)
+int ttm_bo_lock_delayed_workqueue(struct ttm_device *bdev)
 {
 	return cancel_delayed_work_sync(&bdev->wq);
 }
 EXPORT_SYMBOL(ttm_bo_lock_delayed_workqueue);
 
-void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev, int resched)
+void ttm_bo_unlock_delayed_workqueue(struct ttm_device *bdev, int resched)
 {
 	if (resched)
 		schedule_delayed_work(&bdev->wq,
@@ -529,7 +511,7 @@ EXPORT_SYMBOL(ttm_bo_unlock_delayed_workqueue);
 static int ttm_bo_evict(struct ttm_buffer_object *bo,
 			struct ttm_operation_ctx *ctx)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 	struct ttm_resource evict_mem;
 	struct ttm_placement placement;
 	struct ttm_place hop;
@@ -541,7 +523,7 @@ static int ttm_bo_evict(struct ttm_buffer_object *bo,
 
 	placement.num_placement = 0;
 	placement.num_busy_placement = 0;
-	bdev->driver->evict_flags(bo, &placement);
+	bdev->funcs->evict_flags(bo, &placement);
 
 	if (!placement.num_placement && !placement.num_busy_placement) {
 		ttm_bo_wait(bo, false, false);
@@ -657,7 +639,7 @@ static int ttm_mem_evict_wait_busy(struct ttm_buffer_object *busy_bo,
 	return r == -EDEADLK ? -EBUSY : r;
 }
 
-int ttm_mem_evict_first(struct ttm_bo_device *bdev,
+int ttm_mem_evict_first(struct ttm_device *bdev,
 			struct ttm_resource_manager *man,
 			const struct ttm_place *place,
 			struct ttm_operation_ctx *ctx,
@@ -668,7 +650,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
 	unsigned i;
 	int ret;
 
-	spin_lock(&ttm_bo_glob.lru_lock);
+	spin_lock(&ttm_glob.lru_lock);
 	for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i) {
 		list_for_each_entry(bo, &man->lru[i], lru) {
 			bool busy;
@@ -681,7 +663,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
 				continue;
 			}
 
-			if (place && !bdev->driver->eviction_valuable(bo,
+			if (place && !bdev->funcs->eviction_valuable(bo,
 								      place)) {
 				if (locked)
 					dma_resv_unlock(bo->base.resv);
@@ -705,7 +687,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
 	if (!bo) {
 		if (busy_bo && !ttm_bo_get_unless_zero(busy_bo))
 			busy_bo = NULL;
-		spin_unlock(&ttm_bo_glob.lru_lock);
+		spin_unlock(&ttm_glob.lru_lock);
 		ret = ttm_mem_evict_wait_busy(busy_bo, ctx, ticket);
 		if (busy_bo)
 			ttm_bo_put(busy_bo);
@@ -719,7 +701,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
 		return ret;
 	}
 
-	spin_unlock(&ttm_bo_glob.lru_lock);
+	spin_unlock(&ttm_glob.lru_lock);
 
 	ret = ttm_bo_evict(bo, ctx);
 	if (locked)
@@ -774,7 +756,7 @@ static int ttm_bo_mem_force_space(struct ttm_buffer_object *bo,
 				  struct ttm_resource *mem,
 				  struct ttm_operation_ctx *ctx)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 	struct ttm_resource_manager *man = ttm_manager_type(bdev, mem->mem_type);
 	struct ww_acquire_ctx *ticket;
 	int ret;
@@ -809,7 +791,7 @@ static int ttm_bo_mem_placement(struct ttm_buffer_object *bo,
 				const struct ttm_place *place,
 				struct ttm_resource *mem)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 	struct ttm_resource_manager *man;
 
 	man = ttm_manager_type(bdev, place->mem_type);
@@ -819,9 +801,9 @@ static int ttm_bo_mem_placement(struct ttm_buffer_object *bo,
 	mem->mem_type = place->mem_type;
 	mem->placement = place->flags;
 
-	spin_lock(&ttm_bo_glob.lru_lock);
+	spin_lock(&ttm_glob.lru_lock);
 	ttm_bo_move_to_lru_tail(bo, mem, NULL);
-	spin_unlock(&ttm_bo_glob.lru_lock);
+	spin_unlock(&ttm_glob.lru_lock);
 
 	return 0;
 }
@@ -839,7 +821,7 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
 			struct ttm_resource *mem,
 			struct ttm_operation_ctx *ctx)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 	bool type_found = false;
 	int i, ret;
 
@@ -1057,7 +1039,7 @@ int ttm_bo_validate(struct ttm_buffer_object *bo,
 }
 EXPORT_SYMBOL(ttm_bo_validate);
 
-int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
+int ttm_bo_init_reserved(struct ttm_device *bdev,
 			 struct ttm_buffer_object *bo,
 			 size_t size,
 			 enum ttm_bo_type type,
@@ -1117,7 +1099,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
 		dma_resv_init(&bo->base._resv);
 		drm_vma_node_reset(&bo->base.vma_node);
 	}
-	atomic_inc(&ttm_bo_glob.bo_count);
+	atomic_inc(&ttm_glob.bo_count);
 
 	/*
 	 * For ttm_bo_type_device buffers, allocate
@@ -1153,7 +1135,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
 }
 EXPORT_SYMBOL(ttm_bo_init_reserved);
 
-int ttm_bo_init(struct ttm_bo_device *bdev,
+int ttm_bo_init(struct ttm_device *bdev,
 		struct ttm_buffer_object *bo,
 		size_t size,
 		enum ttm_bo_type type,
@@ -1181,7 +1163,7 @@ int ttm_bo_init(struct ttm_bo_device *bdev,
 }
 EXPORT_SYMBOL(ttm_bo_init);
 
-size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
+size_t ttm_bo_dma_acc_size(struct ttm_device *bdev,
 			   unsigned long bo_size,
 			   unsigned struct_size)
 {
@@ -1195,148 +1177,13 @@ size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
 }
 EXPORT_SYMBOL(ttm_bo_dma_acc_size);
 
-static void ttm_bo_global_release(void)
-{
-	struct ttm_bo_global *glob = &ttm_bo_glob;
-
-	mutex_lock(&ttm_global_mutex);
-	if (--ttm_bo_glob_use_count > 0)
-		goto out;
-
-	kobject_del(&glob->kobj);
-	kobject_put(&glob->kobj);
-	ttm_mem_global_release(&ttm_mem_glob);
-	__free_page(glob->dummy_read_page);
-	memset(glob, 0, sizeof(*glob));
-out:
-	mutex_unlock(&ttm_global_mutex);
-}
-
-static int ttm_bo_global_init(void)
-{
-	struct ttm_bo_global *glob = &ttm_bo_glob;
-	int ret = 0;
-	unsigned i;
-
-	mutex_lock(&ttm_global_mutex);
-	if (++ttm_bo_glob_use_count > 1)
-		goto out;
-
-	ret = ttm_mem_global_init(&ttm_mem_glob);
-	if (ret)
-		goto out;
-
-	spin_lock_init(&glob->lru_lock);
-	glob->dummy_read_page = alloc_page(__GFP_ZERO | GFP_DMA32);
-
-	if (unlikely(glob->dummy_read_page == NULL)) {
-		ret = -ENOMEM;
-		goto out;
-	}
-
-	for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
-		INIT_LIST_HEAD(&glob->swap_lru[i]);
-	INIT_LIST_HEAD(&glob->device_list);
-	atomic_set(&glob->bo_count, 0);
-
-	debugfs_create_atomic_t("buffer_objects", 0444, ttm_debugfs_root,
-				&glob->bo_count);
-out:
-	mutex_unlock(&ttm_global_mutex);
-	return ret;
-}
-
-int ttm_bo_device_release(struct ttm_bo_device *bdev)
-{
-	struct ttm_bo_global *glob = &ttm_bo_glob;
-	int ret = 0;
-	unsigned i;
-	struct ttm_resource_manager *man;
-
-	man = ttm_manager_type(bdev, TTM_PL_SYSTEM);
-	ttm_resource_manager_set_used(man, false);
-	ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, NULL);
-
-	mutex_lock(&ttm_global_mutex);
-	list_del(&bdev->device_list);
-	mutex_unlock(&ttm_global_mutex);
-
-	cancel_delayed_work_sync(&bdev->wq);
-
-	if (ttm_bo_delayed_delete(bdev, true))
-		pr_debug("Delayed destroy list was clean\n");
-
-	spin_lock(&glob->lru_lock);
-	for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
-		if (list_empty(&man->lru[0]))
-			pr_debug("Swap list %d was clean\n", i);
-	spin_unlock(&glob->lru_lock);
-
-	ttm_pool_fini(&bdev->pool);
-
-	if (!ret)
-		ttm_bo_global_release();
-
-	return ret;
-}
-EXPORT_SYMBOL(ttm_bo_device_release);
-
-static void ttm_bo_init_sysman(struct ttm_bo_device *bdev)
-{
-	struct ttm_resource_manager *man = &bdev->sysman;
-
-	/*
-	 * Initialize the system memory buffer type.
-	 * Other types need to be driver / IOCTL initialized.
-	 */
-	man->use_tt = true;
-
-	ttm_resource_manager_init(man, 0);
-	ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, man);
-	ttm_resource_manager_set_used(man, true);
-}
-
-int ttm_bo_device_init(struct ttm_bo_device *bdev,
-		       struct ttm_bo_driver *driver,
-		       struct device *dev,
-		       struct address_space *mapping,
-		       struct drm_vma_offset_manager *vma_manager,
-		       bool use_dma_alloc, bool use_dma32)
-{
-	struct ttm_bo_global *glob = &ttm_bo_glob;
-	int ret;
-
-	if (WARN_ON(vma_manager == NULL))
-		return -EINVAL;
-
-	ret = ttm_bo_global_init();
-	if (ret)
-		return ret;
-
-	bdev->driver = driver;
-
-	ttm_bo_init_sysman(bdev);
-	ttm_pool_init(&bdev->pool, dev, use_dma_alloc, use_dma32);
-
-	bdev->vma_manager = vma_manager;
-	INIT_DELAYED_WORK(&bdev->wq, ttm_bo_delayed_workqueue);
-	INIT_LIST_HEAD(&bdev->ddestroy);
-	bdev->dev_mapping = mapping;
-	mutex_lock(&ttm_global_mutex);
-	list_add_tail(&bdev->device_list, &glob->device_list);
-	mutex_unlock(&ttm_global_mutex);
-
-	return 0;
-}
-EXPORT_SYMBOL(ttm_bo_device_init);
-
 /*
  * buffer object vm functions.
  */
 
 void ttm_bo_unmap_virtual(struct ttm_buffer_object *bo)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 
 	drm_vma_node_unmap(&bo->base.vma_node, bdev->dev_mapping);
 	ttm_mem_io_free(bdev, &bo->mem);
@@ -1374,7 +1221,7 @@ EXPORT_SYMBOL(ttm_bo_wait);
  */
 int ttm_bo_swapout(struct ttm_operation_ctx *ctx)
 {
-	struct ttm_bo_global *glob = &ttm_bo_glob;
+	struct ttm_global *glob = &ttm_glob;
 	struct ttm_buffer_object *bo;
 	int ret = -EBUSY;
 	bool locked;
@@ -1452,8 +1299,8 @@ int ttm_bo_swapout(struct ttm_operation_ctx *ctx)
 	 * anyone tries to access a ttm page.
 	 */
 
-	if (bo->bdev->driver->swap_notify)
-		bo->bdev->driver->swap_notify(bo);
+	if (bo->bdev->funcs->swap_notify)
+		bo->bdev->funcs->swap_notify(bo);
 
 	ret = ttm_tt_swapout(bo->bdev, bo->ttm);
 out:
@@ -1478,4 +1325,3 @@ void ttm_bo_tt_destroy(struct ttm_buffer_object *bo)
 	ttm_tt_destroy(bo->bdev, bo->ttm);
 	bo->ttm = NULL;
 }
-
diff --git a/drivers/gpu/drm/ttm/ttm_bo_util.c b/drivers/gpu/drm/ttm/ttm_bo_util.c
index 398d5013fc39..db0f2661d504 100644
--- a/drivers/gpu/drm/ttm/ttm_bo_util.c
+++ b/drivers/gpu/drm/ttm/ttm_bo_util.c
@@ -46,33 +46,33 @@ struct ttm_transfer_obj {
 	struct ttm_buffer_object *bo;
 };
 
-int ttm_mem_io_reserve(struct ttm_bo_device *bdev,
+int ttm_mem_io_reserve(struct ttm_device *bdev,
 		       struct ttm_resource *mem)
 {
 	if (mem->bus.offset || mem->bus.addr)
 		return 0;
 
 	mem->bus.is_iomem = false;
-	if (!bdev->driver->io_mem_reserve)
+	if (!bdev->funcs->io_mem_reserve)
 		return 0;
 
-	return bdev->driver->io_mem_reserve(bdev, mem);
+	return bdev->funcs->io_mem_reserve(bdev, mem);
 }
 
-void ttm_mem_io_free(struct ttm_bo_device *bdev,
+void ttm_mem_io_free(struct ttm_device *bdev,
 		     struct ttm_resource *mem)
 {
 	if (!mem->bus.offset && !mem->bus.addr)
 		return;
 
-	if (bdev->driver->io_mem_free)
-		bdev->driver->io_mem_free(bdev, mem);
+	if (bdev->funcs->io_mem_free)
+		bdev->funcs->io_mem_free(bdev, mem);
 
 	mem->bus.offset = 0;
 	mem->bus.addr = NULL;
 }
 
-static int ttm_resource_ioremap(struct ttm_bo_device *bdev,
+static int ttm_resource_ioremap(struct ttm_device *bdev,
 			       struct ttm_resource *mem,
 			       void **virtual)
 {
@@ -102,7 +102,7 @@ static int ttm_resource_ioremap(struct ttm_bo_device *bdev,
 	return 0;
 }
 
-static void ttm_resource_iounmap(struct ttm_bo_device *bdev,
+static void ttm_resource_iounmap(struct ttm_device *bdev,
 				struct ttm_resource *mem,
 				void *virtual)
 {
@@ -172,7 +172,7 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo,
 		       struct ttm_operation_ctx *ctx,
 		       struct ttm_resource *new_mem)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 	struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type);
 	struct ttm_tt *ttm = bo->ttm;
 	struct ttm_resource *old_mem = &bo->mem;
@@ -300,7 +300,7 @@ static int ttm_buffer_object_transfer(struct ttm_buffer_object *bo,
 	 * TODO: Explicit member copy would probably be better here.
 	 */
 
-	atomic_inc(&ttm_bo_glob.bo_count);
+	atomic_inc(&ttm_glob.bo_count);
 	INIT_LIST_HEAD(&fbo->base.ddestroy);
 	INIT_LIST_HEAD(&fbo->base.lru);
 	INIT_LIST_HEAD(&fbo->base.swap);
@@ -602,7 +602,7 @@ static int ttm_bo_move_to_ghost(struct ttm_buffer_object *bo,
 static void ttm_bo_move_pipeline_evict(struct ttm_buffer_object *bo,
 				       struct dma_fence *fence)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 	struct ttm_resource_manager *from = ttm_manager_type(bdev, bo->mem.mem_type);
 
 	/**
@@ -628,7 +628,7 @@ int ttm_bo_move_accel_cleanup(struct ttm_buffer_object *bo,
 			      bool pipeline,
 			      struct ttm_resource *new_mem)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 	struct ttm_resource_manager *from = ttm_manager_type(bdev, bo->mem.mem_type);
 	struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type);
 	int ret = 0;
diff --git a/drivers/gpu/drm/ttm/ttm_bo_vm.c b/drivers/gpu/drm/ttm/ttm_bo_vm.c
index 6dc96cf66744..b31b18058965 100644
--- a/drivers/gpu/drm/ttm/ttm_bo_vm.c
+++ b/drivers/gpu/drm/ttm/ttm_bo_vm.c
@@ -95,10 +95,10 @@ static vm_fault_t ttm_bo_vm_fault_idle(struct ttm_buffer_object *bo,
 static unsigned long ttm_bo_io_mem_pfn(struct ttm_buffer_object *bo,
 				       unsigned long page_offset)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 
-	if (bdev->driver->io_mem_pfn)
-		return bdev->driver->io_mem_pfn(bo, page_offset);
+	if (bdev->funcs->io_mem_pfn)
+		return bdev->funcs->io_mem_pfn(bo, page_offset);
 
 	return (bo->mem.bus.offset >> PAGE_SHIFT) + page_offset;
 }
@@ -216,7 +216,7 @@ static vm_fault_t ttm_bo_vm_insert_huge(struct vm_fault *vmf,
 			if (page_to_pfn(ttm->pages[page_offset + i]) != pfn + i)
 				goto out_fallback;
 		}
-	} else if (bo->bdev->driver->io_mem_pfn) {
+	} else if (bo->bdev->funcs->io_mem_pfn) {
 		for (i = 1; i < fault_page_size; ++i) {
 			if (ttm_bo_io_mem_pfn(bo, page_offset + i) != pfn + i)
 				goto out_fallback;
@@ -278,7 +278,7 @@ vm_fault_t ttm_bo_vm_fault_reserved(struct vm_fault *vmf,
 {
 	struct vm_area_struct *vma = vmf->vma;
 	struct ttm_buffer_object *bo = vma->vm_private_data;
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 	unsigned long page_offset;
 	unsigned long page_last;
 	unsigned long pfn;
@@ -488,8 +488,8 @@ int ttm_bo_vm_access(struct vm_area_struct *vma, unsigned long addr,
 		ret = ttm_bo_vm_access_kmap(bo, offset, buf, len, write);
 		break;
 	default:
-		if (bo->bdev->driver->access_memory)
-			ret = bo->bdev->driver->access_memory(
+		if (bo->bdev->funcs->access_memory)
+			ret = bo->bdev->funcs->access_memory(
 				bo, offset, buf, len, write);
 		else
 			ret = -EIO;
@@ -508,7 +508,7 @@ static const struct vm_operations_struct ttm_bo_vm_ops = {
 	.access = ttm_bo_vm_access,
 };
 
-static struct ttm_buffer_object *ttm_bo_vm_lookup(struct ttm_bo_device *bdev,
+static struct ttm_buffer_object *ttm_bo_vm_lookup(struct ttm_device *bdev,
 						  unsigned long offset,
 						  unsigned long pages)
 {
@@ -555,9 +555,8 @@ static void ttm_bo_mmap_vma_setup(struct ttm_buffer_object *bo, struct vm_area_s
 }
 
 int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
-		struct ttm_bo_device *bdev)
+		struct ttm_device *bdev)
 {
-	struct ttm_bo_driver *driver;
 	struct ttm_buffer_object *bo;
 	int ret;
 
@@ -568,12 +567,11 @@ int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
 	if (unlikely(!bo))
 		return -EINVAL;
 
-	driver = bo->bdev->driver;
-	if (unlikely(!driver->verify_access)) {
+	if (unlikely(!bo->bdev->funcs->verify_access)) {
 		ret = -EPERM;
 		goto out_unref;
 	}
-	ret = driver->verify_access(bo, filp);
+	ret = bo->bdev->funcs->verify_access(bo, filp);
 	if (unlikely(ret != 0))
 		goto out_unref;
 
diff --git a/drivers/gpu/drm/ttm/ttm_device.c b/drivers/gpu/drm/ttm/ttm_device.c
new file mode 100644
index 000000000000..ac0903c9e60a
--- /dev/null
+++ b/drivers/gpu/drm/ttm/ttm_device.c
@@ -0,0 +1,195 @@
+/* SPDX-License-Identifier: GPL-2.0 OR MIT */
+
+/*
+ * Copyright (c) 2006-2009 VMware, Inc., Palo Alto, CA., USA
+ * Copyright 2020 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: Christian König
+ */
+
+#define pr_fmt(fmt) "[TTM DEVICE] " fmt
+
+#include <drm/ttm/ttm_device.h>
+#include <drm/ttm/ttm_memory.h>
+#include <drm/ttm/ttm_placement.h>
+
+#include "ttm_module.h"
+
+/**
+ * ttm_global_mutex - protecting the global state
+ */
+DEFINE_MUTEX(ttm_global_mutex);
+unsigned ttm_glob_use_count;
+struct ttm_global ttm_glob;
+EXPORT_SYMBOL(ttm_glob);
+
+static void ttm_global_release(void)
+{
+	struct ttm_global *glob = &ttm_glob;
+
+	mutex_lock(&ttm_global_mutex);
+	if (--ttm_glob_use_count > 0)
+		goto out;
+
+	kobject_del(&glob->kobj);
+	kobject_put(&glob->kobj);
+	ttm_mem_global_release(&ttm_mem_glob);
+	__free_page(glob->dummy_read_page);
+	memset(glob, 0, sizeof(*glob));
+out:
+	mutex_unlock(&ttm_global_mutex);
+}
+
+static int ttm_global_init(void)
+{
+	struct ttm_global *glob = &ttm_glob;
+	int ret = 0;
+	unsigned i;
+
+	mutex_lock(&ttm_global_mutex);
+	if (++ttm_glob_use_count > 1)
+		goto out;
+
+	ret = ttm_mem_global_init(&ttm_mem_glob);
+	if (ret)
+		goto out;
+
+	spin_lock_init(&glob->lru_lock);
+	glob->dummy_read_page = alloc_page(__GFP_ZERO | GFP_DMA32);
+
+	if (unlikely(glob->dummy_read_page == NULL)) {
+		ret = -ENOMEM;
+		goto out;
+	}
+
+	for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
+		INIT_LIST_HEAD(&glob->swap_lru[i]);
+	INIT_LIST_HEAD(&glob->device_list);
+	atomic_set(&glob->bo_count, 0);
+
+	debugfs_create_atomic_t("buffer_objects", 0444, ttm_debugfs_root,
+				&glob->bo_count);
+out:
+	mutex_unlock(&ttm_global_mutex);
+	return ret;
+}
+
+static void ttm_init_sysman(struct ttm_device *bdev)
+{
+	struct ttm_resource_manager *man = &bdev->sysman;
+
+	/*
+	 * Initialize the system memory buffer type.
+	 * Other types need to be driver / IOCTL initialized.
+	 */
+	man->use_tt = true;
+
+	ttm_resource_manager_init(man, 0);
+	ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, man);
+	ttm_resource_manager_set_used(man, true);
+}
+
+static void ttm_device_delayed_workqueue(struct work_struct *work)
+{
+	struct ttm_device *bdev =
+		container_of(work, struct ttm_device, wq.work);
+
+	if (!ttm_bo_delayed_delete(bdev, false))
+		schedule_delayed_work(&bdev->wq,
+				      ((HZ / 100) < 1) ? 1 : HZ / 100);
+}
+
+/**
+ * ttm_device_init
+ *
+ * @bdev: A pointer to a struct ttm_device to initialize.
+ * @funcs: Function table for the device.
+ * @dev: The core kernel device pointer for DMA mappings and allocations.
+ * @mapping: The address space to use for this bo.
+ * @vma_manager: A pointer to a vma manager.
+ * @use_dma_alloc: If coherent DMA allocation API should be used.
+ * @use_dma32: If we should use GFP_DMA32 for device memory allocations.
+ *
+ * Initializes a struct ttm_device:
+ * Returns:
+ * !0: Failure.
+ */
+int ttm_device_init(struct ttm_device *bdev, struct ttm_device_funcs *funcs,
+		    struct device *dev, struct address_space *mapping,
+		    struct drm_vma_offset_manager *vma_manager,
+		    bool use_dma_alloc, bool use_dma32)
+{
+	struct ttm_global *glob = &ttm_glob;
+	int ret;
+
+	if (WARN_ON(vma_manager == NULL))
+		return -EINVAL;
+
+	ret = ttm_global_init();
+	if (ret)
+		return ret;
+
+	bdev->funcs = funcs;
+
+	ttm_init_sysman(bdev);
+	ttm_pool_init(&bdev->pool, dev, use_dma_alloc, use_dma32);
+
+	bdev->vma_manager = vma_manager;
+	INIT_DELAYED_WORK(&bdev->wq, ttm_device_delayed_workqueue);
+	INIT_LIST_HEAD(&bdev->ddestroy);
+	bdev->dev_mapping = mapping;
+	mutex_lock(&ttm_global_mutex);
+	list_add_tail(&bdev->device_list, &glob->device_list);
+	mutex_unlock(&ttm_global_mutex);
+
+	return 0;
+}
+EXPORT_SYMBOL(ttm_device_init);
+
+void ttm_device_fini(struct ttm_device *bdev)
+{
+	struct ttm_global *glob = &ttm_glob;
+	struct ttm_resource_manager *man;
+	unsigned i;
+
+	man = ttm_manager_type(bdev, TTM_PL_SYSTEM);
+	ttm_resource_manager_set_used(man, false);
+	ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, NULL);
+
+	mutex_lock(&ttm_global_mutex);
+	list_del(&bdev->device_list);
+	mutex_unlock(&ttm_global_mutex);
+
+	cancel_delayed_work_sync(&bdev->wq);
+
+	if (ttm_bo_delayed_delete(bdev, true))
+		pr_debug("Delayed destroy list was clean\n");
+
+	spin_lock(&glob->lru_lock);
+	for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
+		if (list_empty(&man->lru[0]))
+			pr_debug("Swap list %d was clean\n", i);
+	spin_unlock(&glob->lru_lock);
+
+	ttm_pool_fini(&bdev->pool);
+	ttm_global_release();
+}
+EXPORT_SYMBOL(ttm_device_fini);
diff --git a/drivers/gpu/drm/ttm/ttm_execbuf_util.c b/drivers/gpu/drm/ttm/ttm_execbuf_util.c
index 9fa36ed59429..690ab97d52b7 100644
--- a/drivers/gpu/drm/ttm/ttm_execbuf_util.c
+++ b/drivers/gpu/drm/ttm/ttm_execbuf_util.c
@@ -51,14 +51,14 @@ void ttm_eu_backoff_reservation(struct ww_acquire_ctx *ticket,
 	if (list_empty(list))
 		return;
 
-	spin_lock(&ttm_bo_glob.lru_lock);
+	spin_lock(&ttm_glob.lru_lock);
 	list_for_each_entry(entry, list, head) {
 		struct ttm_buffer_object *bo = entry->bo;
 
 		ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
 		dma_resv_unlock(bo->base.resv);
 	}
-	spin_unlock(&ttm_bo_glob.lru_lock);
+	spin_unlock(&ttm_glob.lru_lock);
 
 	if (ticket)
 		ww_acquire_fini(ticket);
@@ -154,7 +154,7 @@ void ttm_eu_fence_buffer_objects(struct ww_acquire_ctx *ticket,
 	if (list_empty(list))
 		return;
 
-	spin_lock(&ttm_bo_glob.lru_lock);
+	spin_lock(&ttm_glob.lru_lock);
 	list_for_each_entry(entry, list, head) {
 		struct ttm_buffer_object *bo = entry->bo;
 
@@ -165,7 +165,7 @@ void ttm_eu_fence_buffer_objects(struct ww_acquire_ctx *ticket,
 		ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
 		dma_resv_unlock(bo->base.resv);
 	}
-	spin_unlock(&ttm_bo_glob.lru_lock);
+	spin_unlock(&ttm_glob.lru_lock);
 	if (ticket)
 		ww_acquire_fini(ticket);
 }
diff --git a/drivers/gpu/drm/ttm/ttm_range_manager.c b/drivers/gpu/drm/ttm/ttm_range_manager.c
index a39305f742da..707e5c152896 100644
--- a/drivers/gpu/drm/ttm/ttm_range_manager.c
+++ b/drivers/gpu/drm/ttm/ttm_range_manager.c
@@ -111,7 +111,7 @@ static void ttm_range_man_free(struct ttm_resource_manager *man,
 
 static const struct ttm_resource_manager_func ttm_range_manager_func;
 
-int ttm_range_man_init(struct ttm_bo_device *bdev,
+int ttm_range_man_init(struct ttm_device *bdev,
 		       unsigned type, bool use_tt,
 		       unsigned long p_size)
 {
@@ -138,7 +138,7 @@ int ttm_range_man_init(struct ttm_bo_device *bdev,
 }
 EXPORT_SYMBOL(ttm_range_man_init);
 
-int ttm_range_man_fini(struct ttm_bo_device *bdev,
+int ttm_range_man_fini(struct ttm_device *bdev,
 		       unsigned type)
 {
 	struct ttm_resource_manager *man = ttm_manager_type(bdev, type);
diff --git a/drivers/gpu/drm/ttm/ttm_resource.c b/drivers/gpu/drm/ttm/ttm_resource.c
index b60699bf4816..ed1672a9f332 100644
--- a/drivers/gpu/drm/ttm/ttm_resource.c
+++ b/drivers/gpu/drm/ttm/ttm_resource.c
@@ -83,7 +83,7 @@ EXPORT_SYMBOL(ttm_resource_manager_init);
  * Evict all the objects out of a memory manager until it is empty.
  * Part of memory manager cleanup sequence.
  */
-int ttm_resource_manager_evict_all(struct ttm_bo_device *bdev,
+int ttm_resource_manager_evict_all(struct ttm_device *bdev,
 				   struct ttm_resource_manager *man)
 {
 	struct ttm_operation_ctx ctx = {
@@ -91,7 +91,7 @@ int ttm_resource_manager_evict_all(struct ttm_bo_device *bdev,
 		.no_wait_gpu = false,
 		.force_alloc = true
 	};
-	struct ttm_bo_global *glob = &ttm_bo_glob;
+	struct ttm_global *glob = &ttm_glob;
 	struct dma_fence *fence;
 	int ret;
 	unsigned i;
diff --git a/drivers/gpu/drm/ttm/ttm_tt.c b/drivers/gpu/drm/ttm/ttm_tt.c
index 7f75a13163f0..7782d5393c7c 100644
--- a/drivers/gpu/drm/ttm/ttm_tt.c
+++ b/drivers/gpu/drm/ttm/ttm_tt.c
@@ -43,7 +43,7 @@
  */
 int ttm_tt_create(struct ttm_buffer_object *bo, bool zero_alloc)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 	uint32_t page_flags = 0;
 
 	dma_resv_assert_held(bo->base.resv);
@@ -66,7 +66,7 @@ int ttm_tt_create(struct ttm_buffer_object *bo, bool zero_alloc)
 		return -EINVAL;
 	}
 
-	bo->ttm = bdev->driver->ttm_tt_create(bo, page_flags);
+	bo->ttm = bdev->funcs->ttm_tt_create(bo, page_flags);
 	if (unlikely(bo->ttm == NULL))
 		return -ENOMEM;
 
@@ -108,7 +108,7 @@ static int ttm_sg_tt_alloc_page_directory(struct ttm_tt *ttm)
 	return 0;
 }
 
-void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
+void ttm_tt_destroy_common(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
 	ttm_tt_unpopulate(bdev, ttm);
 
@@ -119,9 +119,9 @@ void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
 }
 EXPORT_SYMBOL(ttm_tt_destroy_common);
 
-void ttm_tt_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
+void ttm_tt_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
-	bdev->driver->ttm_tt_destroy(bdev, ttm);
+	bdev->funcs->ttm_tt_destroy(bdev, ttm);
 }
 
 static void ttm_tt_init_fields(struct ttm_tt *ttm,
@@ -223,7 +223,7 @@ int ttm_tt_swapin(struct ttm_tt *ttm)
 	return ret;
 }
 
-int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
+int ttm_tt_swapout(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
 	struct address_space *swap_space;
 	struct file *swap_storage;
@@ -271,7 +271,7 @@ int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
 	return ret;
 }
 
-static void ttm_tt_add_mapping(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
+static void ttm_tt_add_mapping(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
 	pgoff_t i;
 
@@ -282,7 +282,7 @@ static void ttm_tt_add_mapping(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
 		ttm->pages[i]->mapping = bdev->dev_mapping;
 }
 
-int ttm_tt_populate(struct ttm_bo_device *bdev,
+int ttm_tt_populate(struct ttm_device *bdev,
 		    struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)
 {
 	int ret;
@@ -293,8 +293,8 @@ int ttm_tt_populate(struct ttm_bo_device *bdev,
 	if (ttm_tt_is_populated(ttm))
 		return 0;
 
-	if (bdev->driver->ttm_tt_populate)
-		ret = bdev->driver->ttm_tt_populate(bdev, ttm, ctx);
+	if (bdev->funcs->ttm_tt_populate)
+		ret = bdev->funcs->ttm_tt_populate(bdev, ttm, ctx);
 	else
 		ret = ttm_pool_alloc(&bdev->pool, ttm, ctx);
 	if (ret)
@@ -328,15 +328,15 @@ static void ttm_tt_clear_mapping(struct ttm_tt *ttm)
 	}
 }
 
-void ttm_tt_unpopulate(struct ttm_bo_device *bdev,
+void ttm_tt_unpopulate(struct ttm_device *bdev,
 		       struct ttm_tt *ttm)
 {
 	if (!ttm_tt_is_populated(ttm))
 		return;
 
 	ttm_tt_clear_mapping(ttm);
-	if (bdev->driver->ttm_tt_unpopulate)
-		bdev->driver->ttm_tt_unpopulate(bdev, ttm);
+	if (bdev->funcs->ttm_tt_unpopulate)
+		bdev->funcs->ttm_tt_unpopulate(bdev, ttm);
 	else
 		ttm_pool_free(&bdev->pool, ttm);
 	ttm->page_flags &= ~TTM_PAGE_FLAG_PRIV_POPULATED;
diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c b/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c
index 118db24eb756..3a438ae4d3f4 100644
--- a/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c
+++ b/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c
@@ -466,13 +466,13 @@ int vmw_bo_cpu_blit(struct ttm_buffer_object *dst,
 		dma_resv_assert_held(src->base.resv);
 
 	if (!ttm_tt_is_populated(dst->ttm)) {
-		ret = dst->bdev->driver->ttm_tt_populate(dst->bdev, dst->ttm, &ctx);
+		ret = dst->bdev->funcs->ttm_tt_populate(dst->bdev, dst->ttm, &ctx);
 		if (ret)
 			return ret;
 	}
 
 	if (!ttm_tt_is_populated(src->ttm)) {
-		ret = src->bdev->driver->ttm_tt_populate(src->bdev, src->ttm, &ctx);
+		ret = src->bdev->funcs->ttm_tt_populate(src->bdev, src->ttm, &ctx);
 		if (ret)
 			return ret;
 	}
diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c b/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
index ab0844b47d4d..6b3bfd8c678a 100644
--- a/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
+++ b/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
@@ -545,7 +545,7 @@ int vmw_bo_init(struct vmw_private *dev_priv,
 		void (*bo_free)(struct ttm_buffer_object *bo))
 {
 	struct ttm_operation_ctx ctx = { interruptible, false };
-	struct ttm_bo_device *bdev = &dev_priv->bdev;
+	struct ttm_device *bdev = &dev_priv->bdev;
 	size_t acc_size;
 	int ret;
 	bool user = (bo_free == &vmw_user_bo_destroy);
@@ -1058,7 +1058,7 @@ int vmw_user_bo_reference(struct ttm_object_file *tfile,
 void vmw_bo_fence_single(struct ttm_buffer_object *bo,
 			 struct vmw_fence_obj *fence)
 {
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 
 	struct vmw_private *dev_priv =
 		container_of(bdev, struct vmw_private, bdev);
diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
index eb997f4678de..b454d80c273e 100644
--- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
+++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
@@ -884,12 +884,12 @@ static int vmw_driver_load(struct vmw_private *dev_priv, u32 pci_id)
 	drm_vma_offset_manager_init(&dev_priv->vma_manager,
 				    DRM_FILE_PAGE_OFFSET_START,
 				    DRM_FILE_PAGE_OFFSET_SIZE);
-	ret = ttm_bo_device_init(&dev_priv->bdev, &vmw_bo_driver,
-				 dev_priv->drm.dev,
-				 dev_priv->drm.anon_inode->i_mapping,
-				 &dev_priv->vma_manager,
-				 dev_priv->map_mode == vmw_dma_alloc_coherent,
-				 false);
+	ret = ttm_device_init(&dev_priv->bdev, &vmw_bo_driver,
+			      dev_priv->drm.dev,
+			      dev_priv->drm.anon_inode->i_mapping,
+			      &dev_priv->vma_manager,
+			      dev_priv->map_mode == vmw_dma_alloc_coherent,
+			      false);
 	if (unlikely(ret != 0)) {
 		DRM_ERROR("Failed initializing TTM buffer object driver.\n");
 		goto out_no_bdev;
@@ -1006,7 +1006,7 @@ static int vmw_driver_load(struct vmw_private *dev_priv, u32 pci_id)
 		vmw_gmrid_man_fini(dev_priv, VMW_PL_GMR);
 	vmw_vram_manager_fini(dev_priv);
 out_no_vram:
-	(void)ttm_bo_device_release(&dev_priv->bdev);
+	ttm_device_fini(&dev_priv->bdev);
 out_no_bdev:
 	vmw_fence_manager_takedown(dev_priv->fman);
 out_no_fman:
@@ -1053,7 +1053,7 @@ static void vmw_driver_unload(struct drm_device *dev)
 	if (dev_priv->has_mob)
 		vmw_gmrid_man_fini(dev_priv, VMW_PL_MOB);
 	vmw_vram_manager_fini(dev_priv);
-	(void) ttm_bo_device_release(&dev_priv->bdev);
+	ttm_device_fini(&dev_priv->bdev);
 	drm_vma_offset_manager_destroy(&dev_priv->vma_manager);
 	vmw_release_device_late(dev_priv);
 	vmw_fence_manager_takedown(dev_priv->fman);
diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
index 336f5086ca26..e65b00f8336d 100644
--- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
+++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
@@ -484,7 +484,7 @@ enum vmw_sm_type {
 
 struct vmw_private {
 	struct drm_device drm;
-	struct ttm_bo_device bdev;
+	struct ttm_device bdev;
 
 	struct vmw_fifo_state fifo;
 
@@ -999,7 +999,7 @@ extern struct ttm_placement vmw_evictable_placement;
 extern struct ttm_placement vmw_srf_placement;
 extern struct ttm_placement vmw_mob_placement;
 extern struct ttm_placement vmw_nonfixed_placement;
-extern struct ttm_bo_driver vmw_bo_driver;
+extern struct ttm_device_funcs vmw_bo_driver;
 extern const struct vmw_sg_table *
 vmw_bo_sg_table(struct ttm_buffer_object *bo);
 extern int vmw_bo_create_and_populate(struct vmw_private *dev_priv,
diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c b/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c
index c4df51a2a926..c3a724e37104 100644
--- a/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c
+++ b/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c
@@ -856,7 +856,7 @@ void vmw_query_move_notify(struct ttm_buffer_object *bo,
 			   struct ttm_resource *mem)
 {
 	struct vmw_buffer_object *dx_query_mob;
-	struct ttm_bo_device *bdev = bo->bdev;
+	struct ttm_device *bdev = bo->bdev;
 	struct vmw_private *dev_priv;
 
 
diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c b/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c
index 6a44567e4ba5..d1bfa59579f1 100644
--- a/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c
+++ b/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c
@@ -483,7 +483,7 @@ const struct vmw_sg_table *vmw_bo_sg_table(struct ttm_buffer_object *bo)
 }
 
 
-static int vmw_ttm_bind(struct ttm_bo_device *bdev,
+static int vmw_ttm_bind(struct ttm_device *bdev,
 			struct ttm_tt *ttm, struct ttm_resource *bo_mem)
 {
 	struct vmw_ttm_tt *vmw_be =
@@ -527,7 +527,7 @@ static int vmw_ttm_bind(struct ttm_bo_device *bdev,
 	return ret;
 }
 
-static void vmw_ttm_unbind(struct ttm_bo_device *bdev,
+static void vmw_ttm_unbind(struct ttm_device *bdev,
 			   struct ttm_tt *ttm)
 {
 	struct vmw_ttm_tt *vmw_be =
@@ -553,7 +553,7 @@ static void vmw_ttm_unbind(struct ttm_bo_device *bdev,
 }
 
 
-static void vmw_ttm_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
+static void vmw_ttm_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
 {
 	struct vmw_ttm_tt *vmw_be =
 		container_of(ttm, struct vmw_ttm_tt, dma_ttm);
@@ -573,7 +573,7 @@ static void vmw_ttm_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
 }
 
 
-static int vmw_ttm_populate(struct ttm_bo_device *bdev,
+static int vmw_ttm_populate(struct ttm_device *bdev,
 			    struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)
 {
 	/* TODO: maybe completely drop this ? */
@@ -583,7 +583,7 @@ static int vmw_ttm_populate(struct ttm_bo_device *bdev,
 	return ttm_pool_alloc(&bdev->pool, ttm, ctx);
 }
 
-static void vmw_ttm_unpopulate(struct ttm_bo_device *bdev,
+static void vmw_ttm_unpopulate(struct ttm_device *bdev,
 			       struct ttm_tt *ttm)
 {
 	struct vmw_ttm_tt *vmw_tt = container_of(ttm, struct vmw_ttm_tt,
@@ -640,7 +640,7 @@ static int vmw_verify_access(struct ttm_buffer_object *bo, struct file *filp)
 	return vmw_user_bo_verify_access(bo, tfile);
 }
 
-static int vmw_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *mem)
+static int vmw_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *mem)
 {
 	struct vmw_private *dev_priv = container_of(bdev, struct vmw_private, bdev);
 
@@ -744,7 +744,7 @@ vmw_delete_mem_notify(struct ttm_buffer_object *bo)
 	vmw_move_notify(bo, false, NULL);
 }
 
-struct ttm_bo_driver vmw_bo_driver = {
+struct ttm_device_funcs vmw_bo_driver = {
 	.ttm_tt_create = &vmw_ttm_tt_create,
 	.ttm_tt_populate = &vmw_ttm_populate,
 	.ttm_tt_unpopulate = &vmw_ttm_unpopulate,
diff --git a/include/drm/drm_gem_vram_helper.h b/include/drm/drm_gem_vram_helper.h
index a4bac02249c2..288055d397d9 100644
--- a/include/drm/drm_gem_vram_helper.h
+++ b/include/drm/drm_gem_vram_helper.h
@@ -172,19 +172,19 @@ struct drm_vram_mm {
 	uint64_t vram_base;
 	size_t vram_size;
 
-	struct ttm_bo_device bdev;
+	struct ttm_device bdev;
 };
 
 /**
  * drm_vram_mm_of_bdev() - \
-	Returns the container of type &struct ttm_bo_device for field bdev.
+	Returns the container of type &struct ttm_device for field bdev.
  * @bdev:	the TTM BO device
  *
  * Returns:
  * The containing instance of &struct drm_vram_mm
  */
 static inline struct drm_vram_mm *drm_vram_mm_of_bdev(
-	struct ttm_bo_device *bdev)
+	struct ttm_device *bdev)
 {
 	return container_of(bdev, struct drm_vram_mm, bdev);
 }
diff --git a/include/drm/ttm/ttm_bo_api.h b/include/drm/ttm/ttm_bo_api.h
index e17be324d95f..62734db0b421 100644
--- a/include/drm/ttm/ttm_bo_api.h
+++ b/include/drm/ttm/ttm_bo_api.h
@@ -44,9 +44,9 @@
 
 #include "ttm_resource.h"
 
-struct ttm_bo_global;
+struct ttm_global;
 
-struct ttm_bo_device;
+struct ttm_device;
 
 struct dma_buf_map;
 
@@ -122,7 +122,7 @@ struct ttm_buffer_object {
 	 * Members constant at init.
 	 */
 
-	struct ttm_bo_device *bdev;
+	struct ttm_device *bdev;
 	enum ttm_bo_type type;
 	void (*destroy) (struct ttm_buffer_object *);
 	size_t acc_size;
@@ -313,7 +313,7 @@ void ttm_bo_put(struct ttm_buffer_object *bo);
  * @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
+ * object. This function must be called with struct ttm_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,
@@ -326,7 +326,7 @@ void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
  * @bulk: bulk move structure
  *
  * Bulk move BOs to the LRU tail, only valid to use when driver makes sure that
- * BO order never changes. Should be called with ttm_bo_global::lru_lock held.
+ * BO order never changes. Should be called with ttm_global::lru_lock held.
  */
 void ttm_bo_bulk_move_lru_tail(struct ttm_lru_bulk_move *bulk);
 
@@ -337,14 +337,14 @@ void ttm_bo_bulk_move_lru_tail(struct ttm_lru_bulk_move *bulk);
  * Returns
  * True if the workqueue was queued at the time
  */
-int ttm_bo_lock_delayed_workqueue(struct ttm_bo_device *bdev);
+int ttm_bo_lock_delayed_workqueue(struct ttm_device *bdev);
 
 /**
  * ttm_bo_unlock_delayed_workqueue
  *
  * Allows the delayed workqueue to run.
  */
-void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev, int resched);
+void ttm_bo_unlock_delayed_workqueue(struct ttm_device *bdev, int resched);
 
 /**
  * ttm_bo_eviction_valuable
@@ -357,14 +357,14 @@ void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev, int resched);
 bool ttm_bo_eviction_valuable(struct ttm_buffer_object *bo,
 			      const struct ttm_place *place);
 
-size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
+size_t ttm_bo_dma_acc_size(struct ttm_device *bdev,
 			   unsigned long bo_size,
 			   unsigned struct_size);
 
 /**
  * ttm_bo_init_reserved
  *
- * @bdev: Pointer to a ttm_bo_device struct.
+ * @bdev: Pointer to a ttm_device struct.
  * @bo: Pointer to a ttm_buffer_object to be initialized.
  * @size: Requested size of buffer object.
  * @type: Requested type of buffer object.
@@ -396,7 +396,7 @@ size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
  * -ERESTARTSYS: Interrupted by signal while sleeping waiting for resources.
  */
 
-int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
+int ttm_bo_init_reserved(struct ttm_device *bdev,
 			 struct ttm_buffer_object *bo,
 			 size_t size, enum ttm_bo_type type,
 			 struct ttm_placement *placement,
@@ -409,7 +409,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
 /**
  * ttm_bo_init
  *
- * @bdev: Pointer to a ttm_bo_device struct.
+ * @bdev: Pointer to a ttm_device struct.
  * @bo: Pointer to a ttm_buffer_object to be initialized.
  * @size: Requested size of buffer object.
  * @type: Requested type of buffer object.
@@ -443,7 +443,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
  * -EINVAL: Invalid placement flags.
  * -ERESTARTSYS: Interrupted by signal while sleeping waiting for resources.
  */
-int ttm_bo_init(struct ttm_bo_device *bdev, struct ttm_buffer_object *bo,
+int ttm_bo_init(struct ttm_device *bdev, struct ttm_buffer_object *bo,
 		size_t size, enum ttm_bo_type type,
 		struct ttm_placement *placement,
 		uint32_t page_alignment, bool interrubtible, size_t acc_size,
@@ -537,18 +537,18 @@ int ttm_bo_mmap_obj(struct vm_area_struct *vma, struct ttm_buffer_object *bo);
  *
  * @filp:      filp as input from the mmap method.
  * @vma:       vma as input from the mmap method.
- * @bdev:      Pointer to the ttm_bo_device with the address space manager.
+ * @bdev:      Pointer to the ttm_device with the address space manager.
  *
  * This function is intended to be called by the device mmap method.
  * if the device address space is to be backed by the bo manager.
  */
 int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
-		struct ttm_bo_device *bdev);
+		struct ttm_device *bdev);
 
 /**
  * ttm_bo_io
  *
- * @bdev:      Pointer to the struct ttm_bo_device.
+ * @bdev:      Pointer to the struct ttm_device.
  * @filp:      Pointer to the struct file attempting to read / write.
  * @wbuf:      User-space pointer to address of buffer to write. NULL on read.
  * @rbuf:      User-space pointer to address of buffer to read into.
@@ -565,7 +565,7 @@ int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
  * the function may return -ERESTARTSYS if
  * interrupted by a signal.
  */
-ssize_t ttm_bo_io(struct ttm_bo_device *bdev, struct file *filp,
+ssize_t ttm_bo_io(struct ttm_device *bdev, struct file *filp,
 		  const char __user *wbuf, char __user *rbuf,
 		  size_t count, loff_t *f_pos, bool write);
 
@@ -617,7 +617,7 @@ static inline void ttm_bo_unpin(struct ttm_buffer_object *bo)
 	--bo->pin_count;
 }
 
-int ttm_mem_evict_first(struct ttm_bo_device *bdev,
+int ttm_mem_evict_first(struct ttm_device *bdev,
 			struct ttm_resource_manager *man,
 			const struct ttm_place *place,
 			struct ttm_operation_ctx *ctx,
@@ -642,5 +642,6 @@ void ttm_bo_vm_close(struct vm_area_struct *vma);
 
 int ttm_bo_vm_access(struct vm_area_struct *vma, unsigned long addr,
 		     void *buf, int len, int write);
+bool ttm_bo_delayed_delete(struct ttm_device *bdev, bool remove_all);
 
 #endif
diff --git a/include/drm/ttm/ttm_bo_driver.h b/include/drm/ttm/ttm_bo_driver.h
index 423348414c59..1c9bf993e252 100644
--- a/include/drm/ttm/ttm_bo_driver.h
+++ b/include/drm/ttm/ttm_bo_driver.h
@@ -37,301 +37,14 @@
 #include <linux/spinlock.h>
 #include <linux/dma-resv.h>
 
+#include <drm/ttm/ttm_device.h>
+
 #include "ttm_bo_api.h"
 #include "ttm_memory.h"
 #include "ttm_placement.h"
 #include "ttm_tt.h"
 #include "ttm_pool.h"
 
-/**
- * struct ttm_bo_driver
- *
- * @create_ttm_backend_entry: Callback to create a struct ttm_backend.
- * @evict_flags: Callback to obtain placement flags when a buffer is evicted.
- * @move: Callback for a driver to hook in accelerated functions to
- * move a buffer.
- * If set to NULL, a potentially slow memcpy() move is used.
- */
-
-struct ttm_bo_driver {
-	/**
-	 * ttm_tt_create
-	 *
-	 * @bo: The buffer object to create the ttm for.
-	 * @page_flags: Page flags as identified by TTM_PAGE_FLAG_XX flags.
-	 *
-	 * Create a struct ttm_tt to back data with system memory pages.
-	 * No pages are actually allocated.
-	 * Returns:
-	 * NULL: Out of memory.
-	 */
-	struct ttm_tt *(*ttm_tt_create)(struct ttm_buffer_object *bo,
-					uint32_t page_flags);
-
-	/**
-	 * ttm_tt_populate
-	 *
-	 * @ttm: The struct ttm_tt to contain the backing pages.
-	 *
-	 * Allocate all backing pages
-	 * Returns:
-	 * -ENOMEM: Out of memory.
-	 */
-	int (*ttm_tt_populate)(struct ttm_bo_device *bdev,
-			       struct ttm_tt *ttm,
-			       struct ttm_operation_ctx *ctx);
-
-	/**
-	 * ttm_tt_unpopulate
-	 *
-	 * @ttm: The struct ttm_tt to contain the backing pages.
-	 *
-	 * Free all backing page
-	 */
-	void (*ttm_tt_unpopulate)(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
-
-	/**
-	 * ttm_tt_destroy
-	 *
-	 * @bdev: Pointer to a ttm device
-	 * @ttm: Pointer to a struct ttm_tt.
-	 *
-	 * Destroy the backend. This will be call back from ttm_tt_destroy so
-	 * don't call ttm_tt_destroy from the callback or infinite loop.
-	 */
-	void (*ttm_tt_destroy)(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
-
-	/**
-	 * struct ttm_bo_driver member eviction_valuable
-	 *
-	 * @bo: the buffer object to be evicted
-	 * @place: placement we need room for
-	 *
-	 * Check with the driver if it is valuable to evict a BO to make room
-	 * for a certain placement.
-	 */
-	bool (*eviction_valuable)(struct ttm_buffer_object *bo,
-				  const struct ttm_place *place);
-	/**
-	 * struct ttm_bo_driver member evict_flags:
-	 *
-	 * @bo: the buffer object to be evicted
-	 *
-	 * Return the bo flags for a buffer which is not mapped to the hardware.
-	 * These will be placed in proposed_flags so that when the move is
-	 * finished, they'll end up in bo->mem.flags
-	 * This should not cause multihop evictions, and the core will warn
-	 * if one is proposed.
-	 */
-
-	void (*evict_flags)(struct ttm_buffer_object *bo,
-			    struct ttm_placement *placement);
-
-	/**
-	 * struct ttm_bo_driver member move:
-	 *
-	 * @bo: the buffer to move
-	 * @evict: whether this motion is evicting the buffer from
-	 * the graphics address space
-	 * @ctx: context for this move with parameters
-	 * @new_mem: the new memory region receiving the buffer
-	 @ @hop: placement for driver directed intermediate hop
-	 *
-	 * Move a buffer between two memory regions.
-	 * Returns errno -EMULTIHOP if driver requests a hop
-	 */
-	int (*move)(struct ttm_buffer_object *bo, bool evict,
-		    struct ttm_operation_ctx *ctx,
-		    struct ttm_resource *new_mem,
-		    struct ttm_place *hop);
-
-	/**
-	 * struct ttm_bo_driver_member verify_access
-	 *
-	 * @bo: Pointer to a buffer object.
-	 * @filp: Pointer to a struct file trying to access the object.
-	 *
-	 * Called from the map / write / read methods to verify that the
-	 * caller is permitted to access the buffer object.
-	 * This member may be set to NULL, which will refuse this kind of
-	 * access for all buffer objects.
-	 * This function should return 0 if access is granted, -EPERM otherwise.
-	 */
-	int (*verify_access)(struct ttm_buffer_object *bo,
-			     struct file *filp);
-
-	/**
-	 * Hook to notify driver about a resource delete.
-	 */
-	void (*delete_mem_notify)(struct ttm_buffer_object *bo);
-
-	/**
-	 * notify the driver that we're about to swap out this bo
-	 */
-	void (*swap_notify)(struct ttm_buffer_object *bo);
-
-	/**
-	 * Driver callback on when mapping io memory (for bo_move_memcpy
-	 * for instance). TTM will take care to call io_mem_free whenever
-	 * the mapping is not use anymore. io_mem_reserve & io_mem_free
-	 * are balanced.
-	 */
-	int (*io_mem_reserve)(struct ttm_bo_device *bdev,
-			      struct ttm_resource *mem);
-	void (*io_mem_free)(struct ttm_bo_device *bdev,
-			    struct ttm_resource *mem);
-
-	/**
-	 * Return the pfn for a given page_offset inside the BO.
-	 *
-	 * @bo: the BO to look up the pfn for
-	 * @page_offset: the offset to look up
-	 */
-	unsigned long (*io_mem_pfn)(struct ttm_buffer_object *bo,
-				    unsigned long page_offset);
-
-	/**
-	 * Read/write memory buffers for ptrace access
-	 *
-	 * @bo: the BO to access
-	 * @offset: the offset from the start of the BO
-	 * @buf: pointer to source/destination buffer
-	 * @len: number of bytes to copy
-	 * @write: whether to read (0) from or write (non-0) to BO
-	 *
-	 * If successful, this function should return the number of
-	 * bytes copied, -EIO otherwise. If the number of bytes
-	 * returned is < len, the function may be called again with
-	 * the remainder of the buffer to copy.
-	 */
-	int (*access_memory)(struct ttm_buffer_object *bo, unsigned long offset,
-			     void *buf, int len, int write);
-
-	/**
-	 * struct ttm_bo_driver member del_from_lru_notify
-	 *
-	 * @bo: the buffer object deleted from lru
-	 *
-	 * notify driver that a BO was deleted from LRU.
-	 */
-	void (*del_from_lru_notify)(struct ttm_buffer_object *bo);
-
-	/**
-	 * Notify the driver that we're about to release a BO
-	 *
-	 * @bo: BO that is about to be released
-	 *
-	 * Gives the driver a chance to do any cleanup, including
-	 * adding fences that may force a delayed delete
-	 */
-	void (*release_notify)(struct ttm_buffer_object *bo);
-};
-
-/**
- * struct ttm_bo_global - Buffer object driver global data.
- *
- * @dummy_read_page: Pointer to a dummy page used for mapping requests
- * of unpopulated pages.
- * @shrink: A shrink callback object used for buffer object swap.
- * @device_list_mutex: Mutex protecting the device list.
- * This mutex is held while traversing the device list for pm options.
- * @lru_lock: Spinlock protecting the bo subsystem lru lists.
- * @device_list: List of buffer object devices.
- * @swap_lru: Lru list of buffer objects used for swapping.
- */
-
-extern struct ttm_bo_global {
-
-	/**
-	 * Constant after init.
-	 */
-
-	struct kobject kobj;
-	struct page *dummy_read_page;
-	spinlock_t lru_lock;
-
-	/**
-	 * Protected by ttm_global_mutex.
-	 */
-	struct list_head device_list;
-
-	/**
-	 * Protected by the lru_lock.
-	 */
-	struct list_head swap_lru[TTM_MAX_BO_PRIORITY];
-
-	/**
-	 * Internal protection.
-	 */
-	atomic_t bo_count;
-} ttm_bo_glob;
-
-
-#define TTM_NUM_MEM_TYPES 8
-
-/**
- * struct ttm_bo_device - Buffer object driver device-specific data.
- *
- * @driver: Pointer to a struct ttm_bo_driver struct setup by the driver.
- * @man: An array of resource_managers.
- * @vma_manager: Address space manager (pointer)
- * lru_lock: Spinlock that protects the buffer+device lru lists and
- * ddestroy lists.
- * @dev_mapping: A pointer to the struct address_space representing the
- * device address space.
- * @wq: Work queue structure for the delayed delete workqueue.
- *
- */
-
-struct ttm_bo_device {
-
-	/*
-	 * Constant after bo device init / atomic.
-	 */
-	struct list_head device_list;
-	struct ttm_bo_driver *driver;
-	/*
-	 * access via ttm_manager_type.
-	 */
-	struct ttm_resource_manager sysman;
-	struct ttm_resource_manager *man_drv[TTM_NUM_MEM_TYPES];
-	/*
-	 * Protected by internal locks.
-	 */
-	struct drm_vma_offset_manager *vma_manager;
-	struct ttm_pool pool;
-
-	/*
-	 * Protected by the global:lru lock.
-	 */
-	struct list_head ddestroy;
-
-	/*
-	 * Protected by load / firstopen / lastclose /unload sync.
-	 */
-
-	struct address_space *dev_mapping;
-
-	/*
-	 * Internal protection.
-	 */
-
-	struct delayed_work wq;
-};
-
-static inline struct ttm_resource_manager *ttm_manager_type(struct ttm_bo_device *bdev,
-							    int mem_type)
-{
-	return bdev->man_drv[mem_type];
-}
-
-static inline void ttm_set_driver_manager(struct ttm_bo_device *bdev,
-					  int type,
-					  struct ttm_resource_manager *manager)
-{
-	bdev->man_drv[type] = manager;
-}
-
 /**
  * struct ttm_lru_bulk_move_pos
  *
@@ -388,31 +101,6 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
 		     struct ttm_resource *mem,
 		     struct ttm_operation_ctx *ctx);
 
-int ttm_bo_device_release(struct ttm_bo_device *bdev);
-
-/**
- * ttm_bo_device_init
- *
- * @bdev: A pointer to a struct ttm_bo_device to initialize.
- * @glob: A pointer to an initialized struct ttm_bo_global.
- * @driver: A pointer to a struct ttm_bo_driver set up by the caller.
- * @dev: The core kernel device pointer for DMA mappings and allocations.
- * @mapping: The address space to use for this bo.
- * @vma_manager: A pointer to a vma manager.
- * @use_dma_alloc: If coherent DMA allocation API should be used.
- * @use_dma32: If we should use GFP_DMA32 for device memory allocations.
- *
- * Initializes a struct ttm_bo_device:
- * Returns:
- * !0: Failure.
- */
-int ttm_bo_device_init(struct ttm_bo_device *bdev,
-		       struct ttm_bo_driver *driver,
-		       struct device *dev,
-		       struct address_space *mapping,
-		       struct drm_vma_offset_manager *vma_manager,
-		       bool use_dma_alloc, bool use_dma32);
-
 /**
  * ttm_bo_unmap_virtual
  *
@@ -494,9 +182,9 @@ static inline int ttm_bo_reserve_slowpath(struct ttm_buffer_object *bo,
 static inline void
 ttm_bo_move_to_lru_tail_unlocked(struct ttm_buffer_object *bo)
 {
-	spin_lock(&ttm_bo_glob.lru_lock);
+	spin_lock(&ttm_glob.lru_lock);
 	ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
-	spin_unlock(&ttm_bo_glob.lru_lock);
+	spin_unlock(&ttm_glob.lru_lock);
 }
 
 static inline void ttm_bo_assign_mem(struct ttm_buffer_object *bo,
@@ -538,9 +226,9 @@ static inline void ttm_bo_unreserve(struct ttm_buffer_object *bo)
 /*
  * ttm_bo_util.c
  */
-int ttm_mem_io_reserve(struct ttm_bo_device *bdev,
+int ttm_mem_io_reserve(struct ttm_device *bdev,
 		       struct ttm_resource *mem);
-void ttm_mem_io_free(struct ttm_bo_device *bdev,
+void ttm_mem_io_free(struct ttm_device *bdev,
 		     struct ttm_resource *mem);
 
 /**
@@ -631,7 +319,7 @@ void ttm_bo_tt_destroy(struct ttm_buffer_object *bo);
  * Initialise a generic range manager for the selected memory type.
  * The range manager is installed for this device in the type slot.
  */
-int ttm_range_man_init(struct ttm_bo_device *bdev,
+int ttm_range_man_init(struct ttm_device *bdev,
 		       unsigned type, bool use_tt,
 		       unsigned long p_size);
 
@@ -643,7 +331,7 @@ int ttm_range_man_init(struct ttm_bo_device *bdev,
  *
  * Remove the generic range manager from a slot and tear it down.
  */
-int ttm_range_man_fini(struct ttm_bo_device *bdev,
+int ttm_range_man_fini(struct ttm_device *bdev,
 		       unsigned type);
 
 #endif
diff --git a/include/drm/ttm/ttm_device.h b/include/drm/ttm/ttm_device.h
new file mode 100644
index 000000000000..7bc8bb797161
--- /dev/null
+++ b/include/drm/ttm/ttm_device.h
@@ -0,0 +1,319 @@
+/*
+ * Copyright 2020 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: Christian König
+ */
+
+#ifndef _TTM_DEVICE_H_
+#define _TTM_DEVICE_H_
+
+#include <linux/types.h>
+#include <linux/workqueue.h>
+#include <drm/ttm/ttm_resource.h>
+#include <drm/ttm/ttm_pool.h>
+
+#define TTM_NUM_MEM_TYPES 8
+
+struct ttm_device;
+struct ttm_placement;
+struct ttm_buffer_object;
+struct ttm_operation_ctx;
+
+/**
+ * struct ttm_global - Buffer object driver global data.
+ *
+ * @dummy_read_page: Pointer to a dummy page used for mapping requests
+ * of unpopulated pages.
+ * @shrink: A shrink callback object used for buffer object swap.
+ * @device_list_mutex: Mutex protecting the device list.
+ * This mutex is held while traversing the device list for pm options.
+ * @lru_lock: Spinlock protecting the bo subsystem lru lists.
+ * @device_list: List of buffer object devices.
+ * @swap_lru: Lru list of buffer objects used for swapping.
+ */
+extern struct ttm_global {
+
+	/**
+	 * Constant after init.
+	 */
+
+	struct kobject kobj;
+	struct page *dummy_read_page;
+	spinlock_t lru_lock;
+
+	/**
+	 * Protected by ttm_global_mutex.
+	 */
+	struct list_head device_list;
+
+	/**
+	 * Protected by the lru_lock.
+	 */
+	struct list_head swap_lru[TTM_MAX_BO_PRIORITY];
+
+	/**
+	 * Internal protection.
+	 */
+	atomic_t bo_count;
+} ttm_glob;
+
+struct ttm_device_funcs {
+	/**
+	 * ttm_tt_create
+	 *
+	 * @bo: The buffer object to create the ttm for.
+	 * @page_flags: Page flags as identified by TTM_PAGE_FLAG_XX flags.
+	 *
+	 * Create a struct ttm_tt to back data with system memory pages.
+	 * No pages are actually allocated.
+	 * Returns:
+	 * NULL: Out of memory.
+	 */
+	struct ttm_tt *(*ttm_tt_create)(struct ttm_buffer_object *bo,
+					uint32_t page_flags);
+
+	/**
+	 * ttm_tt_populate
+	 *
+	 * @ttm: The struct ttm_tt to contain the backing pages.
+	 *
+	 * Allocate all backing pages
+	 * Returns:
+	 * -ENOMEM: Out of memory.
+	 */
+	int (*ttm_tt_populate)(struct ttm_device *bdev,
+			       struct ttm_tt *ttm,
+			       struct ttm_operation_ctx *ctx);
+
+	/**
+	 * ttm_tt_unpopulate
+	 *
+	 * @ttm: The struct ttm_tt to contain the backing pages.
+	 *
+	 * Free all backing page
+	 */
+	void (*ttm_tt_unpopulate)(struct ttm_device *bdev,
+				  struct ttm_tt *ttm);
+
+	/**
+	 * ttm_tt_destroy
+	 *
+	 * @bdev: Pointer to a ttm device
+	 * @ttm: Pointer to a struct ttm_tt.
+	 *
+	 * Destroy the backend. This will be call back from ttm_tt_destroy so
+	 * don't call ttm_tt_destroy from the callback or infinite loop.
+	 */
+	void (*ttm_tt_destroy)(struct ttm_device *bdev, struct ttm_tt *ttm);
+
+	/**
+	 * struct ttm_bo_driver member eviction_valuable
+	 *
+	 * @bo: the buffer object to be evicted
+	 * @place: placement we need room for
+	 *
+	 * Check with the driver if it is valuable to evict a BO to make room
+	 * for a certain placement.
+	 */
+	bool (*eviction_valuable)(struct ttm_buffer_object *bo,
+				  const struct ttm_place *place);
+	/**
+	 * struct ttm_bo_driver member evict_flags:
+	 *
+	 * @bo: the buffer object to be evicted
+	 *
+	 * Return the bo flags for a buffer which is not mapped to the hardware.
+	 * These will be placed in proposed_flags so that when the move is
+	 * finished, they'll end up in bo->mem.flags
+	 * This should not cause multihop evictions, and the core will warn
+	 * if one is proposed.
+	 */
+
+	void (*evict_flags)(struct ttm_buffer_object *bo,
+			    struct ttm_placement *placement);
+
+	/**
+	 * struct ttm_bo_driver member move:
+	 *
+	 * @bo: the buffer to move
+	 * @evict: whether this motion is evicting the buffer from
+	 * the graphics address space
+	 * @ctx: context for this move with parameters
+	 * @new_mem: the new memory region receiving the buffer
+	 @ @hop: placement for driver directed intermediate hop
+	 *
+	 * Move a buffer between two memory regions.
+	 * Returns errno -EMULTIHOP if driver requests a hop
+	 */
+	int (*move)(struct ttm_buffer_object *bo, bool evict,
+		    struct ttm_operation_ctx *ctx,
+		    struct ttm_resource *new_mem,
+		    struct ttm_place *hop);
+
+	/**
+	 * struct ttm_bo_driver_member verify_access
+	 *
+	 * @bo: Pointer to a buffer object.
+	 * @filp: Pointer to a struct file trying to access the object.
+	 *
+	 * Called from the map / write / read methods to verify that the
+	 * caller is permitted to access the buffer object.
+	 * This member may be set to NULL, which will refuse this kind of
+	 * access for all buffer objects.
+	 * This function should return 0 if access is granted, -EPERM otherwise.
+	 */
+	int (*verify_access)(struct ttm_buffer_object *bo,
+			     struct file *filp);
+
+	/**
+	 * Hook to notify driver about a resource delete.
+	 */
+	void (*delete_mem_notify)(struct ttm_buffer_object *bo);
+
+	/**
+	 * notify the driver that we're about to swap out this bo
+	 */
+	void (*swap_notify)(struct ttm_buffer_object *bo);
+
+	/**
+	 * Driver callback on when mapping io memory (for bo_move_memcpy
+	 * for instance). TTM will take care to call io_mem_free whenever
+	 * the mapping is not use anymore. io_mem_reserve & io_mem_free
+	 * are balanced.
+	 */
+	int (*io_mem_reserve)(struct ttm_device *bdev,
+			      struct ttm_resource *mem);
+	void (*io_mem_free)(struct ttm_device *bdev,
+			    struct ttm_resource *mem);
+
+	/**
+	 * Return the pfn for a given page_offset inside the BO.
+	 *
+	 * @bo: the BO to look up the pfn for
+	 * @page_offset: the offset to look up
+	 */
+	unsigned long (*io_mem_pfn)(struct ttm_buffer_object *bo,
+				    unsigned long page_offset);
+
+	/**
+	 * Read/write memory buffers for ptrace access
+	 *
+	 * @bo: the BO to access
+	 * @offset: the offset from the start of the BO
+	 * @buf: pointer to source/destination buffer
+	 * @len: number of bytes to copy
+	 * @write: whether to read (0) from or write (non-0) to BO
+	 *
+	 * If successful, this function should return the number of
+	 * bytes copied, -EIO otherwise. If the number of bytes
+	 * returned is < len, the function may be called again with
+	 * the remainder of the buffer to copy.
+	 */
+	int (*access_memory)(struct ttm_buffer_object *bo, unsigned long offset,
+			     void *buf, int len, int write);
+
+	/**
+	 * struct ttm_bo_driver member del_from_lru_notify
+	 *
+	 * @bo: the buffer object deleted from lru
+	 *
+	 * notify driver that a BO was deleted from LRU.
+	 */
+	void (*del_from_lru_notify)(struct ttm_buffer_object *bo);
+
+	/**
+	 * Notify the driver that we're about to release a BO
+	 *
+	 * @bo: BO that is about to be released
+	 *
+	 * Gives the driver a chance to do any cleanup, including
+	 * adding fences that may force a delayed delete
+	 */
+	void (*release_notify)(struct ttm_buffer_object *bo);
+};
+
+/**
+ * struct ttm_device - Buffer object driver device-specific data.
+ *
+ * @device_list: Our entry in the global device list.
+ * @funcs: Function table for the device.
+ * @sysman: Resource manager for the system domain.
+ * @man_drv: An array of resource_managers.
+ * @vma_manager: Address space manager.
+ * @pool: page pool for the device.
+ * @dev_mapping: A pointer to the struct address_space representing the
+ * device address space.
+ * @wq: Work queue structure for the delayed delete workqueue.
+ */
+struct ttm_device {
+	/*
+	 * Constant after bo device init
+	 */
+	struct list_head device_list;
+	struct ttm_device_funcs *funcs;
+
+	/*
+	 * Access via ttm_manager_type.
+	 */
+	struct ttm_resource_manager sysman;
+	struct ttm_resource_manager *man_drv[TTM_NUM_MEM_TYPES];
+
+	/*
+	 * Protected by internal locks.
+	 */
+	struct drm_vma_offset_manager *vma_manager;
+	struct ttm_pool pool;
+
+	/*
+	 * Protected by the global:lru lock.
+	 */
+	struct list_head ddestroy;
+
+	/*
+	 * Protected by load / firstopen / lastclose /unload sync.
+	 */
+	struct address_space *dev_mapping;
+
+	/*
+	 * Internal protection.
+	 */
+	struct delayed_work wq;
+};
+
+static inline struct ttm_resource_manager *
+ttm_manager_type(struct ttm_device *bdev, int mem_type)
+{
+	return bdev->man_drv[mem_type];
+}
+
+static inline void ttm_set_driver_manager(struct ttm_device *bdev, int type,
+					  struct ttm_resource_manager *manager)
+{
+	bdev->man_drv[type] = manager;
+}
+
+int ttm_device_init(struct ttm_device *bdev, struct ttm_device_funcs *funcs,
+		    struct device *dev, struct address_space *mapping,
+		    struct drm_vma_offset_manager *vma_manager,
+		    bool use_dma_alloc, bool use_dma32);
+void ttm_device_fini(struct ttm_device *bdev);
+
+#endif
diff --git a/include/drm/ttm/ttm_resource.h b/include/drm/ttm/ttm_resource.h
index da0ed7e8c915..6164ccf4f308 100644
--- a/include/drm/ttm/ttm_resource.h
+++ b/include/drm/ttm/ttm_resource.h
@@ -33,7 +33,7 @@
 
 #define TTM_MAX_BO_PRIORITY	4U
 
-struct ttm_bo_device;
+struct ttm_device;
 struct ttm_resource_manager;
 struct ttm_resource;
 struct ttm_place;
@@ -233,7 +233,7 @@ void ttm_resource_free(struct ttm_buffer_object *bo, struct ttm_resource *res);
 void ttm_resource_manager_init(struct ttm_resource_manager *man,
 			       unsigned long p_size);
 
-int ttm_resource_manager_evict_all(struct ttm_bo_device *bdev,
+int ttm_resource_manager_evict_all(struct ttm_device *bdev,
 				   struct ttm_resource_manager *man);
 
 void ttm_resource_manager_debug(struct ttm_resource_manager *man,
diff --git a/include/drm/ttm/ttm_tt.h b/include/drm/ttm/ttm_tt.h
index 6c8eb9a4de81..0020a0588985 100644
--- a/include/drm/ttm/ttm_tt.h
+++ b/include/drm/ttm/ttm_tt.h
@@ -118,14 +118,14 @@ void ttm_tt_fini(struct ttm_tt *ttm);
  *
  * Unbind, unpopulate and destroy common struct ttm_tt.
  */
-void ttm_tt_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
+void ttm_tt_destroy(struct ttm_device *bdev, struct ttm_tt *ttm);
 
 /**
  * ttm_tt_destroy_common:
  *
  * Called from driver to destroy common path.
  */
-void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
+void ttm_tt_destroy_common(struct ttm_device *bdev, struct ttm_tt *ttm);
 
 /**
  * ttm_tt_swapin:
@@ -135,7 +135,7 @@ void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
  * Swap in a previously swap out ttm_tt.
  */
 int ttm_tt_swapin(struct ttm_tt *ttm);
-int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
+int ttm_tt_swapout(struct ttm_device *bdev, struct ttm_tt *ttm);
 
 /**
  * ttm_tt_populate - allocate pages for a ttm
@@ -144,7 +144,7 @@ int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
  *
  * Calls the driver method to allocate pages for a ttm
  */
-int ttm_tt_populate(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_operation_ctx *ctx);
+int ttm_tt_populate(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_operation_ctx *ctx);
 
 /**
  * ttm_tt_unpopulate - free pages from a ttm
@@ -153,7 +153,7 @@ int ttm_tt_populate(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_o
  *
  * Calls the driver method to free all pages from a ttm
  */
-void ttm_tt_unpopulate(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
+void ttm_tt_unpopulate(struct ttm_device *bdev, struct ttm_tt *ttm);
 
 #if IS_ENABLED(CONFIG_AGP)
 #include <linux/agp_backend.h>
-- 
2.25.1

_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* Re: [PATCH] drm/ttm: device naming cleanup
  2021-01-21 11:58 [PATCH] drm/ttm: device naming cleanup Christian König
@ 2021-01-21 13:39 ` Daniel Vetter
  2021-01-21 13:45   ` Christian König
  2021-01-22  8:27 ` Huang Rui
  1 sibling, 1 reply; 4+ messages in thread
From: Daniel Vetter @ 2021-01-21 13:39 UTC (permalink / raw)
  To: Christian König; +Cc: Huang Rui, dri-devel

On Thu, Jan 21, 2021 at 12:58 PM Christian König
<ckoenig.leichtzumerken@gmail.com> wrote:
>
> Rename ttm_bo_device to ttm_device.
> Rename ttm_bo_driver to ttm_device_funcs.
> Rename ttm_bo_global to ttm_global.
>
> Move global and device related functions to ttm_device.[ch].
>
> No functional change.
>
> Signed-off-by: Christian König <christian.koenig@amd.com>

I didn't check it all, but makes a lot of sense to do this.

Acked-by: Daniel Vetter <daniel.vetter@ffwll.ch>

> ---
>  drivers/gpu/drm/amd/amdgpu/amdgpu.h           |   2 +-
>  .../gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c  |   6 +-
>  drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c      |   2 +-
>  drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c       |  26 +-
>  drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h       |   2 +-
>  drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c        |   8 +-
>  drivers/gpu/drm/drm_gem_vram_helper.c         |  14 +-
>  drivers/gpu/drm/nouveau/nouveau_bo.c          |  20 +-
>  drivers/gpu/drm/nouveau/nouveau_bo.h          |   2 +-
>  drivers/gpu/drm/nouveau/nouveau_drv.h         |   2 +-
>  drivers/gpu/drm/nouveau/nouveau_sgdma.c       |   6 +-
>  drivers/gpu/drm/nouveau/nouveau_ttm.c         |  10 +-
>  drivers/gpu/drm/nouveau/nouveau_ttm.h         |   8 +-
>  drivers/gpu/drm/qxl/qxl_drv.h                 |   4 +-
>  drivers/gpu/drm/qxl/qxl_release.c             |   6 +-
>  drivers/gpu/drm/qxl/qxl_ttm.c                 |  19 +-
>  drivers/gpu/drm/radeon/radeon.h               |   6 +-
>  drivers/gpu/drm/radeon/radeon_object.c        |   2 +-
>  drivers/gpu/drm/radeon/radeon_ttm.c           |  38 +-
>  drivers/gpu/drm/ttm/Makefile                  |   2 +-
>  drivers/gpu/drm/ttm/ttm_agp_backend.c         |   2 +-
>  drivers/gpu/drm/ttm/ttm_bo.c                  | 256 +++-----------
>  drivers/gpu/drm/ttm/ttm_bo_util.c             |  24 +-
>  drivers/gpu/drm/ttm/ttm_bo_vm.c               |  24 +-
>  drivers/gpu/drm/ttm/ttm_device.c              | 195 +++++++++++
>  drivers/gpu/drm/ttm/ttm_execbuf_util.c        |   8 +-
>  drivers/gpu/drm/ttm/ttm_range_manager.c       |   4 +-
>  drivers/gpu/drm/ttm/ttm_resource.c            |   4 +-
>  drivers/gpu/drm/ttm/ttm_tt.c                  |  26 +-
>  drivers/gpu/drm/vmwgfx/vmwgfx_blit.c          |   4 +-
>  drivers/gpu/drm/vmwgfx/vmwgfx_bo.c            |   4 +-
>  drivers/gpu/drm/vmwgfx/vmwgfx_drv.c           |  16 +-
>  drivers/gpu/drm/vmwgfx/vmwgfx_drv.h           |   4 +-
>  drivers/gpu/drm/vmwgfx/vmwgfx_resource.c      |   2 +-
>  drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c    |  14 +-
>  include/drm/drm_gem_vram_helper.h             |   6 +-
>  include/drm/ttm/ttm_bo_api.h                  |  35 +-
>  include/drm/ttm/ttm_bo_driver.h               | 328 +-----------------
>  include/drm/ttm/ttm_device.h                  | 319 +++++++++++++++++
>  include/drm/ttm/ttm_resource.h                |   4 +-
>  include/drm/ttm/ttm_tt.h                      |  10 +-
>  41 files changed, 759 insertions(+), 715 deletions(-)
>  create mode 100644 drivers/gpu/drm/ttm/ttm_device.c
>  create mode 100644 include/drm/ttm/ttm_device.h
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu.h b/drivers/gpu/drm/amd/amdgpu/amdgpu.h
> index f77443cd9c17..ab4ac3b2651e 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu.h
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu.h
> @@ -1053,7 +1053,7 @@ static inline struct drm_device *adev_to_drm(struct amdgpu_device *adev)
>         return &adev->ddev;
>  }
>
> -static inline struct amdgpu_device *amdgpu_ttm_adev(struct ttm_bo_device *bdev)
> +static inline struct amdgpu_device *amdgpu_ttm_adev(struct ttm_device *bdev)
>  {
>         return container_of(bdev, struct amdgpu_device, mman.bdev);
>  }
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c
> index 3107b9575929..5af464933976 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c
> @@ -40,13 +40,13 @@ static atomic_t fence_seq = ATOMIC_INIT(0);
>   * All the BOs in a process share an eviction fence. When process X wants
>   * to map VRAM memory but TTM can't find enough space, TTM will attempt to
>   * evict BOs from its LRU list. TTM checks if the BO is valuable to evict
> - * by calling ttm_bo_driver->eviction_valuable().
> + * by calling ttm_device_funcs->eviction_valuable().
>   *
> - * ttm_bo_driver->eviction_valuable() - will return false if the BO belongs
> + * ttm_device_funcs->eviction_valuable() - will return false if the BO belongs
>   *  to process X. Otherwise, it will return true to indicate BO can be
>   *  evicted by TTM.
>   *
> - * If ttm_bo_driver->eviction_valuable returns true, then TTM will continue
> + * If ttm_device_funcs->eviction_valuable returns true, then TTM will continue
>   * the evcition process for that BO by calling ttm_bo_evict --> amdgpu_bo_move
>   * --> amdgpu_copy_buffer(). This sets up job in GPU scheduler.
>   *
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c
> index 0db933026722..fde2d899b2c4 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c
> @@ -71,7 +71,7 @@
>   */
>  static int amdgpu_gart_dummy_page_init(struct amdgpu_device *adev)
>  {
> -       struct page *dummy_page = ttm_bo_glob.dummy_read_page;
> +       struct page *dummy_page = ttm_glob.dummy_read_page;
>
>         if (adev->dummy_page_addr)
>                 return 0;
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
> index 9fd2157b133a..29cfb0809634 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
> @@ -61,10 +61,10 @@
>
>  #define AMDGPU_TTM_VRAM_MAX_DW_READ    (size_t)128
>
> -static int amdgpu_ttm_backend_bind(struct ttm_bo_device *bdev,
> +static int amdgpu_ttm_backend_bind(struct ttm_device *bdev,
>                                    struct ttm_tt *ttm,
>                                    struct ttm_resource *bo_mem);
> -static void amdgpu_ttm_backend_unbind(struct ttm_bo_device *bdev,
> +static void amdgpu_ttm_backend_unbind(struct ttm_device *bdev,
>                                       struct ttm_tt *ttm);
>
>  static int amdgpu_ttm_init_on_chip(struct amdgpu_device *adev,
> @@ -646,7 +646,7 @@ static int amdgpu_bo_move(struct ttm_buffer_object *bo, bool evict,
>   *
>   * Called by ttm_mem_io_reserve() ultimately via ttm_bo_vm_fault()
>   */
> -static int amdgpu_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *mem)
> +static int amdgpu_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *mem)
>  {
>         struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
>         struct drm_mm_node *mm_node = mem->mm_node;
> @@ -893,7 +893,7 @@ void amdgpu_ttm_tt_set_user_pages(struct ttm_tt *ttm, struct page **pages)
>   *
>   * Called by amdgpu_ttm_backend_bind()
>   **/
> -static int amdgpu_ttm_tt_pin_userptr(struct ttm_bo_device *bdev,
> +static int amdgpu_ttm_tt_pin_userptr(struct ttm_device *bdev,
>                                      struct ttm_tt *ttm)
>  {
>         struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
> @@ -931,7 +931,7 @@ static int amdgpu_ttm_tt_pin_userptr(struct ttm_bo_device *bdev,
>  /*
>   * amdgpu_ttm_tt_unpin_userptr - Unpin and unmap userptr pages
>   */
> -static void amdgpu_ttm_tt_unpin_userptr(struct ttm_bo_device *bdev,
> +static void amdgpu_ttm_tt_unpin_userptr(struct ttm_device *bdev,
>                                         struct ttm_tt *ttm)
>  {
>         struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
> @@ -1015,7 +1015,7 @@ static int amdgpu_ttm_gart_bind(struct amdgpu_device *adev,
>   * Called by ttm_tt_bind() on behalf of ttm_bo_handle_move_mem().
>   * This handles binding GTT memory to the device address space.
>   */
> -static int amdgpu_ttm_backend_bind(struct ttm_bo_device *bdev,
> +static int amdgpu_ttm_backend_bind(struct ttm_device *bdev,
>                                    struct ttm_tt *ttm,
>                                    struct ttm_resource *bo_mem)
>  {
> @@ -1155,7 +1155,7 @@ int amdgpu_ttm_recover_gart(struct ttm_buffer_object *tbo)
>   * Called by ttm_tt_unbind() on behalf of ttm_bo_move_ttm() and
>   * ttm_tt_destroy().
>   */
> -static void amdgpu_ttm_backend_unbind(struct ttm_bo_device *bdev,
> +static void amdgpu_ttm_backend_unbind(struct ttm_device *bdev,
>                                       struct ttm_tt *ttm)
>  {
>         struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
> @@ -1180,7 +1180,7 @@ static void amdgpu_ttm_backend_unbind(struct ttm_bo_device *bdev,
>         gtt->bound = false;
>  }
>
> -static void amdgpu_ttm_backend_destroy(struct ttm_bo_device *bdev,
> +static void amdgpu_ttm_backend_destroy(struct ttm_device *bdev,
>                                        struct ttm_tt *ttm)
>  {
>         struct amdgpu_ttm_tt *gtt = (void *)ttm;
> @@ -1234,7 +1234,7 @@ static struct ttm_tt *amdgpu_ttm_tt_create(struct ttm_buffer_object *bo,
>   * Map the pages of a ttm_tt object to an address space visible
>   * to the underlying device.
>   */
> -static int amdgpu_ttm_tt_populate(struct ttm_bo_device *bdev,
> +static int amdgpu_ttm_tt_populate(struct ttm_device *bdev,
>                                   struct ttm_tt *ttm,
>                                   struct ttm_operation_ctx *ctx)
>  {
> @@ -1278,7 +1278,7 @@ static int amdgpu_ttm_tt_populate(struct ttm_bo_device *bdev,
>   * Unmaps pages of a ttm_tt object from the device address space and
>   * unpopulates the page array backing it.
>   */
> -static void amdgpu_ttm_tt_unpopulate(struct ttm_bo_device *bdev,
> +static void amdgpu_ttm_tt_unpopulate(struct ttm_device *bdev,
>                                      struct ttm_tt *ttm)
>  {
>         struct amdgpu_ttm_tt *gtt = (void *)ttm;
> @@ -1603,7 +1603,7 @@ amdgpu_bo_delete_mem_notify(struct ttm_buffer_object *bo)
>         amdgpu_bo_move_notify(bo, false, NULL);
>  }
>
> -static struct ttm_bo_driver amdgpu_bo_driver = {
> +static struct ttm_device_funcs amdgpu_bo_driver = {
>         .ttm_tt_create = &amdgpu_ttm_tt_create,
>         .ttm_tt_populate = &amdgpu_ttm_tt_populate,
>         .ttm_tt_unpopulate = &amdgpu_ttm_tt_unpopulate,
> @@ -1785,7 +1785,7 @@ int amdgpu_ttm_init(struct amdgpu_device *adev)
>         mutex_init(&adev->mman.gtt_window_lock);
>
>         /* No others user of address space so set it to 0 */
> -       r = ttm_bo_device_init(&adev->mman.bdev, &amdgpu_bo_driver, adev->dev,
> +       r = ttm_device_init(&adev->mman.bdev, &amdgpu_bo_driver, adev->dev,
>                                adev_to_drm(adev)->anon_inode->i_mapping,
>                                adev_to_drm(adev)->vma_offset_manager,
>                                adev->need_swiotlb,
> @@ -1926,7 +1926,7 @@ void amdgpu_ttm_fini(struct amdgpu_device *adev)
>         ttm_range_man_fini(&adev->mman.bdev, AMDGPU_PL_GDS);
>         ttm_range_man_fini(&adev->mman.bdev, AMDGPU_PL_GWS);
>         ttm_range_man_fini(&adev->mman.bdev, AMDGPU_PL_OA);
> -       ttm_bo_device_release(&adev->mman.bdev);
> +       ttm_device_fini(&adev->mman.bdev);
>         adev->mman.initialized = false;
>         DRM_INFO("amdgpu: ttm finalized\n");
>  }
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h
> index d2987536d7cd..7189f8370108 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h
> @@ -60,7 +60,7 @@ struct amdgpu_gtt_mgr {
>  };
>
>  struct amdgpu_mman {
> -       struct ttm_bo_device            bdev;
> +       struct ttm_device               bdev;
>         bool                            initialized;
>         void __iomem                    *aper_base_kaddr;
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
> index ad91c0c3c423..9d19078246c8 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
> @@ -638,15 +638,15 @@ void amdgpu_vm_move_to_lru_tail(struct amdgpu_device *adev,
>         struct amdgpu_vm_bo_base *bo_base;
>
>         if (vm->bulk_moveable) {
> -               spin_lock(&ttm_bo_glob.lru_lock);
> +               spin_lock(&ttm_glob.lru_lock);
>                 ttm_bo_bulk_move_lru_tail(&vm->lru_bulk_move);
> -               spin_unlock(&ttm_bo_glob.lru_lock);
> +               spin_unlock(&ttm_glob.lru_lock);
>                 return;
>         }
>
>         memset(&vm->lru_bulk_move, 0, sizeof(vm->lru_bulk_move));
>
> -       spin_lock(&ttm_bo_glob.lru_lock);
> +       spin_lock(&ttm_glob.lru_lock);
>         list_for_each_entry(bo_base, &vm->idle, vm_status) {
>                 struct amdgpu_bo *bo = bo_base->bo;
>
> @@ -660,7 +660,7 @@ void amdgpu_vm_move_to_lru_tail(struct amdgpu_device *adev,
>                                                 &bo->shadow->tbo.mem,
>                                                 &vm->lru_bulk_move);
>         }
> -       spin_unlock(&ttm_bo_glob.lru_lock);
> +       spin_unlock(&ttm_glob.lru_lock);
>
>         vm->bulk_moveable = true;
>  }
> diff --git a/drivers/gpu/drm/drm_gem_vram_helper.c b/drivers/gpu/drm/drm_gem_vram_helper.c
> index 02ca22e90290..0b13c8507688 100644
> --- a/drivers/gpu/drm/drm_gem_vram_helper.c
> +++ b/drivers/gpu/drm/drm_gem_vram_helper.c
> @@ -187,7 +187,7 @@ struct drm_gem_vram_object *drm_gem_vram_create(struct drm_device *dev,
>         struct drm_gem_vram_object *gbo;
>         struct drm_gem_object *gem;
>         struct drm_vram_mm *vmm = dev->vram_mm;
> -       struct ttm_bo_device *bdev;
> +       struct ttm_device *bdev;
>         int ret;
>         size_t acc_size;
>
> @@ -551,7 +551,7 @@ int drm_gem_vram_fill_create_dumb(struct drm_file *file,
>  EXPORT_SYMBOL(drm_gem_vram_fill_create_dumb);
>
>  /*
> - * Helpers for struct ttm_bo_driver
> + * Helpers for struct ttm_device_funcs
>   */
>
>  static bool drm_is_gem_vram(struct ttm_buffer_object *bo)
> @@ -893,7 +893,7 @@ static const struct drm_gem_object_funcs drm_gem_vram_object_funcs = {
>   * TTM TT
>   */
>
> -static void bo_driver_ttm_tt_destroy(struct ttm_bo_device *bdev, struct ttm_tt *tt)
> +static void bo_driver_ttm_tt_destroy(struct ttm_device *bdev, struct ttm_tt *tt)
>  {
>         ttm_tt_destroy_common(bdev, tt);
>         ttm_tt_fini(tt);
> @@ -965,7 +965,7 @@ static int bo_driver_move(struct ttm_buffer_object *bo,
>         return drm_gem_vram_bo_driver_move(gbo, evict, ctx, new_mem);
>  }
>
> -static int bo_driver_io_mem_reserve(struct ttm_bo_device *bdev,
> +static int bo_driver_io_mem_reserve(struct ttm_device *bdev,
>                                     struct ttm_resource *mem)
>  {
>         struct drm_vram_mm *vmm = drm_vram_mm_of_bdev(bdev);
> @@ -985,7 +985,7 @@ static int bo_driver_io_mem_reserve(struct ttm_bo_device *bdev,
>         return 0;
>  }
>
> -static struct ttm_bo_driver bo_driver = {
> +static struct ttm_device_funcs bo_driver = {
>         .ttm_tt_create = bo_driver_ttm_tt_create,
>         .ttm_tt_destroy = bo_driver_ttm_tt_destroy,
>         .eviction_valuable = ttm_bo_eviction_valuable,
> @@ -1036,7 +1036,7 @@ static int drm_vram_mm_init(struct drm_vram_mm *vmm, struct drm_device *dev,
>         vmm->vram_base = vram_base;
>         vmm->vram_size = vram_size;
>
> -       ret = ttm_bo_device_init(&vmm->bdev, &bo_driver, dev->dev,
> +       ret = ttm_device_init(&vmm->bdev, &bo_driver, dev->dev,
>                                  dev->anon_inode->i_mapping,
>                                  dev->vma_offset_manager,
>                                  false, true);
> @@ -1054,7 +1054,7 @@ static int drm_vram_mm_init(struct drm_vram_mm *vmm, struct drm_device *dev,
>  static void drm_vram_mm_cleanup(struct drm_vram_mm *vmm)
>  {
>         ttm_range_man_fini(&vmm->bdev, TTM_PL_VRAM);
> -       ttm_bo_device_release(&vmm->bdev);
> +       ttm_device_fini(&vmm->bdev);
>  }
>
>  /*
> diff --git a/drivers/gpu/drm/nouveau/nouveau_bo.c b/drivers/gpu/drm/nouveau/nouveau_bo.c
> index 33dc886d1d6d..c177940d6e2c 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_bo.c
> +++ b/drivers/gpu/drm/nouveau/nouveau_bo.c
> @@ -43,9 +43,9 @@
>  #include <nvif/if500b.h>
>  #include <nvif/if900b.h>
>
> -static int nouveau_ttm_tt_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm,
> +static int nouveau_ttm_tt_bind(struct ttm_device *bdev, struct ttm_tt *ttm,
>                                struct ttm_resource *reg);
> -static void nouveau_ttm_tt_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +static void nouveau_ttm_tt_unbind(struct ttm_device *bdev, struct ttm_tt *ttm);
>
>  /*
>   * NV10-NV40 tiling helpers
> @@ -674,7 +674,7 @@ nouveau_ttm_tt_create(struct ttm_buffer_object *bo, uint32_t page_flags)
>  }
>
>  static int
> -nouveau_ttm_tt_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm,
> +nouveau_ttm_tt_bind(struct ttm_device *bdev, struct ttm_tt *ttm,
>                     struct ttm_resource *reg)
>  {
>  #if IS_ENABLED(CONFIG_AGP)
> @@ -690,7 +690,7 @@ nouveau_ttm_tt_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm,
>  }
>
>  static void
> -nouveau_ttm_tt_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +nouveau_ttm_tt_unbind(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  #if IS_ENABLED(CONFIG_AGP)
>         struct nouveau_drm *drm = nouveau_bdev(bdev);
> @@ -1055,7 +1055,7 @@ nouveau_ttm_io_mem_free_locked(struct nouveau_drm *drm,
>  }
>
>  static int
> -nouveau_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *reg)
> +nouveau_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *reg)
>  {
>         struct nouveau_drm *drm = nouveau_bdev(bdev);
>         struct nvkm_device *device = nvxx_device(&drm->client.device);
> @@ -1163,7 +1163,7 @@ nouveau_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *reg)
>  }
>
>  static void
> -nouveau_ttm_io_mem_free(struct ttm_bo_device *bdev, struct ttm_resource *reg)
> +nouveau_ttm_io_mem_free(struct ttm_device *bdev, struct ttm_resource *reg)
>  {
>         struct nouveau_drm *drm = nouveau_bdev(bdev);
>
> @@ -1223,7 +1223,7 @@ vm_fault_t nouveau_ttm_fault_reserve_notify(struct ttm_buffer_object *bo)
>  }
>
>  static int
> -nouveau_ttm_tt_populate(struct ttm_bo_device *bdev,
> +nouveau_ttm_tt_populate(struct ttm_device *bdev,
>                         struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)
>  {
>         struct ttm_tt *ttm_dma = (void *)ttm;
> @@ -1247,7 +1247,7 @@ nouveau_ttm_tt_populate(struct ttm_bo_device *bdev,
>  }
>
>  static void
> -nouveau_ttm_tt_unpopulate(struct ttm_bo_device *bdev,
> +nouveau_ttm_tt_unpopulate(struct ttm_device *bdev,
>                           struct ttm_tt *ttm)
>  {
>         struct nouveau_drm *drm;
> @@ -1264,7 +1264,7 @@ nouveau_ttm_tt_unpopulate(struct ttm_bo_device *bdev,
>  }
>
>  static void
> -nouveau_ttm_tt_destroy(struct ttm_bo_device *bdev,
> +nouveau_ttm_tt_destroy(struct ttm_device *bdev,
>                        struct ttm_tt *ttm)
>  {
>  #if IS_ENABLED(CONFIG_AGP)
> @@ -1296,7 +1296,7 @@ nouveau_bo_delete_mem_notify(struct ttm_buffer_object *bo)
>         nouveau_bo_move_ntfy(bo, false, NULL);
>  }
>
> -struct ttm_bo_driver nouveau_bo_driver = {
> +struct ttm_device_funcs nouveau_bo_driver = {
>         .ttm_tt_create = &nouveau_ttm_tt_create,
>         .ttm_tt_populate = &nouveau_ttm_tt_populate,
>         .ttm_tt_unpopulate = &nouveau_ttm_tt_unpopulate,
> diff --git a/drivers/gpu/drm/nouveau/nouveau_bo.h b/drivers/gpu/drm/nouveau/nouveau_bo.h
> index 6045b85a762a..c2d3f9c48eba 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_bo.h
> +++ b/drivers/gpu/drm/nouveau/nouveau_bo.h
> @@ -68,7 +68,7 @@ nouveau_bo_ref(struct nouveau_bo *ref, struct nouveau_bo **pnvbo)
>         return 0;
>  }
>
> -extern struct ttm_bo_driver nouveau_bo_driver;
> +extern struct ttm_device_funcs nouveau_bo_driver;
>
>  void nouveau_bo_move_init(struct nouveau_drm *);
>  struct nouveau_bo *nouveau_bo_alloc(struct nouveau_cli *, u64 *size, int *align,
> diff --git a/drivers/gpu/drm/nouveau/nouveau_drv.h b/drivers/gpu/drm/nouveau/nouveau_drv.h
> index c802d3d1ba39..edf9d1ee9d58 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_drv.h
> +++ b/drivers/gpu/drm/nouveau/nouveau_drv.h
> @@ -151,7 +151,7 @@ struct nouveau_drm {
>
>         /* TTM interface support */
>         struct {
> -               struct ttm_bo_device bdev;
> +               struct ttm_device bdev;
>                 atomic_t validate_sequence;
>                 int (*move)(struct nouveau_channel *,
>                             struct ttm_buffer_object *,
> diff --git a/drivers/gpu/drm/nouveau/nouveau_sgdma.c b/drivers/gpu/drm/nouveau/nouveau_sgdma.c
> index 1cf52635ea74..256ec5b35473 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_sgdma.c
> +++ b/drivers/gpu/drm/nouveau/nouveau_sgdma.c
> @@ -16,7 +16,7 @@ struct nouveau_sgdma_be {
>  };
>
>  void
> -nouveau_sgdma_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +nouveau_sgdma_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>         struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm;
>
> @@ -29,7 +29,7 @@ nouveau_sgdma_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>  }
>
>  int
> -nouveau_sgdma_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg)
> +nouveau_sgdma_bind(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg)
>  {
>         struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm;
>         struct nouveau_drm *drm = nouveau_bdev(bdev);
> @@ -56,7 +56,7 @@ nouveau_sgdma_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_re
>  }
>
>  void
> -nouveau_sgdma_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +nouveau_sgdma_unbind(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>         struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm;
>         if (nvbe->mem) {
> diff --git a/drivers/gpu/drm/nouveau/nouveau_ttm.c b/drivers/gpu/drm/nouveau/nouveau_ttm.c
> index a37bc3d7b38b..495288182c2d 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_ttm.c
> +++ b/drivers/gpu/drm/nouveau/nouveau_ttm.c
> @@ -324,10 +324,10 @@ nouveau_ttm_init(struct nouveau_drm *drm)
>         need_swiotlb = !!swiotlb_nr_tbl();
>  #endif
>
> -       ret = ttm_bo_device_init(&drm->ttm.bdev, &nouveau_bo_driver,
> -                                drm->dev->dev, dev->anon_inode->i_mapping,
> -                                dev->vma_offset_manager, need_swiotlb,
> -                                drm->client.mmu.dmabits <= 32);
> +       ret = ttm_device_init(&drm->ttm.bdev, &nouveau_bo_driver, drm->dev->dev,
> +                                 dev->anon_inode->i_mapping,
> +                                 dev->vma_offset_manager, need_swiotlb,
> +                                 drm->client.mmu.dmabits <= 32);
>         if (ret) {
>                 NV_ERROR(drm, "error initialising bo driver, %d\n", ret);
>                 return ret;
> @@ -377,7 +377,7 @@ nouveau_ttm_fini(struct nouveau_drm *drm)
>         nouveau_ttm_fini_vram(drm);
>         nouveau_ttm_fini_gtt(drm);
>
> -       ttm_bo_device_release(&drm->ttm.bdev);
> +       ttm_device_fini(&drm->ttm.bdev);
>
>         arch_phys_wc_del(drm->ttm.mtrr);
>         drm->ttm.mtrr = 0;
> diff --git a/drivers/gpu/drm/nouveau/nouveau_ttm.h b/drivers/gpu/drm/nouveau/nouveau_ttm.h
> index 69552049bb96..dbf6dc238efd 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_ttm.h
> +++ b/drivers/gpu/drm/nouveau/nouveau_ttm.h
> @@ -3,7 +3,7 @@
>  #define __NOUVEAU_TTM_H__
>
>  static inline struct nouveau_drm *
> -nouveau_bdev(struct ttm_bo_device *bd)
> +nouveau_bdev(struct ttm_device *bd)
>  {
>         return container_of(bd, struct nouveau_drm, ttm.bdev);
>  }
> @@ -22,7 +22,7 @@ int  nouveau_ttm_mmap(struct file *, struct vm_area_struct *);
>  int  nouveau_ttm_global_init(struct nouveau_drm *);
>  void nouveau_ttm_global_release(struct nouveau_drm *);
>
> -int nouveau_sgdma_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg);
> -void nouveau_sgdma_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> -void nouveau_sgdma_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +int nouveau_sgdma_bind(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg);
> +void nouveau_sgdma_unbind(struct ttm_device *bdev, struct ttm_tt *ttm);
> +void nouveau_sgdma_destroy(struct ttm_device *bdev, struct ttm_tt *ttm);
>  #endif
> diff --git a/drivers/gpu/drm/qxl/qxl_drv.h b/drivers/gpu/drm/qxl/qxl_drv.h
> index 83b54f0dad61..01354b43c413 100644
> --- a/drivers/gpu/drm/qxl/qxl_drv.h
> +++ b/drivers/gpu/drm/qxl/qxl_drv.h
> @@ -125,7 +125,7 @@ struct qxl_output {
>  #define drm_encoder_to_qxl_output(x) container_of(x, struct qxl_output, enc)
>
>  struct qxl_mman {
> -       struct ttm_bo_device            bdev;
> +       struct ttm_device               bdev;
>  };
>
>  struct qxl_memslot {
> @@ -335,7 +335,7 @@ int qxl_mode_dumb_mmap(struct drm_file *filp,
>  /* qxl ttm */
>  int qxl_ttm_init(struct qxl_device *qdev);
>  void qxl_ttm_fini(struct qxl_device *qdev);
> -int qxl_ttm_io_mem_reserve(struct ttm_bo_device *bdev,
> +int qxl_ttm_io_mem_reserve(struct ttm_device *bdev,
>                            struct ttm_resource *mem);
>
>  /* qxl image */
> diff --git a/drivers/gpu/drm/qxl/qxl_release.c b/drivers/gpu/drm/qxl/qxl_release.c
> index 0fcfc952d5e9..c52412724c26 100644
> --- a/drivers/gpu/drm/qxl/qxl_release.c
> +++ b/drivers/gpu/drm/qxl/qxl_release.c
> @@ -429,7 +429,7 @@ void qxl_release_unmap(struct qxl_device *qdev,
>  void qxl_release_fence_buffer_objects(struct qxl_release *release)
>  {
>         struct ttm_buffer_object *bo;
> -       struct ttm_bo_device *bdev;
> +       struct ttm_device *bdev;
>         struct ttm_validate_buffer *entry;
>         struct qxl_device *qdev;
>
> @@ -450,7 +450,7 @@ void qxl_release_fence_buffer_objects(struct qxl_release *release)
>                        release->id | 0xf0000000, release->base.seqno);
>         trace_dma_fence_emit(&release->base);
>
> -       spin_lock(&ttm_bo_glob.lru_lock);
> +       spin_lock(&ttm_glob.lru_lock);
>
>         list_for_each_entry(entry, &release->bos, head) {
>                 bo = entry->bo;
> @@ -459,7 +459,7 @@ void qxl_release_fence_buffer_objects(struct qxl_release *release)
>                 ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
>                 dma_resv_unlock(bo->base.resv);
>         }
> -       spin_unlock(&ttm_bo_glob.lru_lock);
> +       spin_unlock(&ttm_glob.lru_lock);
>         ww_acquire_fini(&release->ticket);
>  }
>
> diff --git a/drivers/gpu/drm/qxl/qxl_ttm.c b/drivers/gpu/drm/qxl/qxl_ttm.c
> index 33c09dc94f8b..b7f77eb685cb 100644
> --- a/drivers/gpu/drm/qxl/qxl_ttm.c
> +++ b/drivers/gpu/drm/qxl/qxl_ttm.c
> @@ -36,7 +36,7 @@
>  #include "qxl_drv.h"
>  #include "qxl_object.h"
>
> -static struct qxl_device *qxl_get_qdev(struct ttm_bo_device *bdev)
> +static struct qxl_device *qxl_get_qdev(struct ttm_device *bdev)
>  {
>         struct qxl_mman *mman;
>         struct qxl_device *qdev;
> @@ -69,7 +69,7 @@ static void qxl_evict_flags(struct ttm_buffer_object *bo,
>         *placement = qbo->placement;
>  }
>
> -int qxl_ttm_io_mem_reserve(struct ttm_bo_device *bdev,
> +int qxl_ttm_io_mem_reserve(struct ttm_device *bdev,
>                            struct ttm_resource *mem)
>  {
>         struct qxl_device *qdev = qxl_get_qdev(bdev);
> @@ -98,8 +98,7 @@ int qxl_ttm_io_mem_reserve(struct ttm_bo_device *bdev,
>  /*
>   * TTM backend functions.
>   */
> -static void qxl_ttm_backend_destroy(struct ttm_bo_device *bdev,
> -                                   struct ttm_tt *ttm)
> +static void qxl_ttm_backend_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>         ttm_tt_destroy_common(bdev, ttm);
>         ttm_tt_fini(ttm);
> @@ -170,7 +169,7 @@ static void qxl_bo_delete_mem_notify(struct ttm_buffer_object *bo)
>         qxl_bo_move_notify(bo, false, NULL);
>  }
>
> -static struct ttm_bo_driver qxl_bo_driver = {
> +static struct ttm_device_funcs qxl_bo_driver = {
>         .ttm_tt_create = &qxl_ttm_tt_create,
>         .ttm_tt_destroy = &qxl_ttm_backend_destroy,
>         .eviction_valuable = ttm_bo_eviction_valuable,
> @@ -193,10 +192,10 @@ int qxl_ttm_init(struct qxl_device *qdev)
>         int num_io_pages; /* != rom->num_io_pages, we include surface0 */
>
>         /* No others user of address space so set it to 0 */
> -       r = ttm_bo_device_init(&qdev->mman.bdev, &qxl_bo_driver, NULL,
> -                              qdev->ddev.anon_inode->i_mapping,
> -                              qdev->ddev.vma_offset_manager,
> -                              false, false);
> +       r = ttm_device_init(&qdev->mman.bdev, &qxl_bo_driver, NULL,
> +                           qdev->ddev.anon_inode->i_mapping,
> +                           qdev->ddev.vma_offset_manager,
> +                           false, false);
>         if (r) {
>                 DRM_ERROR("failed initializing buffer object driver(%d).\n", r);
>                 return r;
> @@ -227,7 +226,7 @@ void qxl_ttm_fini(struct qxl_device *qdev)
>  {
>         ttm_range_man_fini(&qdev->mman.bdev, TTM_PL_VRAM);
>         ttm_range_man_fini(&qdev->mman.bdev, TTM_PL_PRIV);
> -       ttm_bo_device_release(&qdev->mman.bdev);
> +       ttm_device_fini(&qdev->mman.bdev);
>         DRM_INFO("qxl: ttm finalized\n");
>  }
>
> diff --git a/drivers/gpu/drm/radeon/radeon.h b/drivers/gpu/drm/radeon/radeon.h
> index f09989bdce98..449ba0095ed9 100644
> --- a/drivers/gpu/drm/radeon/radeon.h
> +++ b/drivers/gpu/drm/radeon/radeon.h
> @@ -451,7 +451,7 @@ struct radeon_surface_reg {
>   * TTM.
>   */
>  struct radeon_mman {
> -       struct ttm_bo_device            bdev;
> +       struct ttm_device               bdev;
>         bool                            initialized;
>
>  #if defined(CONFIG_DEBUG_FS)
> @@ -2822,7 +2822,7 @@ extern int radeon_ttm_tt_set_userptr(struct radeon_device *rdev,
>                                      uint32_t flags);
>  extern bool radeon_ttm_tt_has_userptr(struct radeon_device *rdev, struct ttm_tt *ttm);
>  extern bool radeon_ttm_tt_is_readonly(struct radeon_device *rdev, struct ttm_tt *ttm);
> -bool radeon_ttm_tt_is_bound(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +bool radeon_ttm_tt_is_bound(struct ttm_device *bdev, struct ttm_tt *ttm);
>  extern void radeon_vram_location(struct radeon_device *rdev, struct radeon_mc *mc, u64 base);
>  extern void radeon_gtt_location(struct radeon_device *rdev, struct radeon_mc *mc);
>  extern int radeon_resume_kms(struct drm_device *dev, bool resume, bool fbcon);
> @@ -2832,7 +2832,7 @@ extern void radeon_ttm_set_active_vram_size(struct radeon_device *rdev, u64 size
>  extern void radeon_program_register_sequence(struct radeon_device *rdev,
>                                              const u32 *registers,
>                                              const u32 array_size);
> -struct radeon_device *radeon_get_rdev(struct ttm_bo_device *bdev);
> +struct radeon_device *radeon_get_rdev(struct ttm_device *bdev);
>
>  /* KMS */
>
> diff --git a/drivers/gpu/drm/radeon/radeon_object.c b/drivers/gpu/drm/radeon/radeon_object.c
> index 9b81786782de..6a336284466f 100644
> --- a/drivers/gpu/drm/radeon/radeon_object.c
> +++ b/drivers/gpu/drm/radeon/radeon_object.c
> @@ -372,7 +372,7 @@ void radeon_bo_unpin(struct radeon_bo *bo)
>
>  int radeon_bo_evict_vram(struct radeon_device *rdev)
>  {
> -       struct ttm_bo_device *bdev = &rdev->mman.bdev;
> +       struct ttm_device *bdev = &rdev->mman.bdev;
>         struct ttm_resource_manager *man;
>
>         /* late 2.6.33 fix IGP hibernate - we need pm ops to do this correct */
> diff --git a/drivers/gpu/drm/radeon/radeon_ttm.c b/drivers/gpu/drm/radeon/radeon_ttm.c
> index c6d575f50c48..5ed6a48246d6 100644
> --- a/drivers/gpu/drm/radeon/radeon_ttm.c
> +++ b/drivers/gpu/drm/radeon/radeon_ttm.c
> @@ -55,13 +55,11 @@
>  static int radeon_ttm_debugfs_init(struct radeon_device *rdev);
>  static void radeon_ttm_debugfs_fini(struct radeon_device *rdev);
>
> -static int radeon_ttm_tt_bind(struct ttm_bo_device *bdev,
> -                             struct ttm_tt *ttm,
> +static int radeon_ttm_tt_bind(struct ttm_device *bdev, struct ttm_tt *ttm,
>                               struct ttm_resource *bo_mem);
> -static void radeon_ttm_tt_unbind(struct ttm_bo_device *bdev,
> -                                struct ttm_tt *ttm);
> +static void radeon_ttm_tt_unbind(struct ttm_device *bdev, struct ttm_tt *ttm);
>
> -struct radeon_device *radeon_get_rdev(struct ttm_bo_device *bdev)
> +struct radeon_device *radeon_get_rdev(struct ttm_device *bdev)
>  {
>         struct radeon_mman *mman;
>         struct radeon_device *rdev;
> @@ -280,7 +278,7 @@ static int radeon_bo_move(struct ttm_buffer_object *bo, bool evict,
>         return 0;
>  }
>
> -static int radeon_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *mem)
> +static int radeon_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *mem)
>  {
>         struct radeon_device *rdev = radeon_get_rdev(bdev);
>         size_t bus_size = (size_t)mem->num_pages << PAGE_SHIFT;
> @@ -347,7 +345,7 @@ struct radeon_ttm_tt {
>  };
>
>  /* prepare the sg table with the user pages */
> -static int radeon_ttm_tt_pin_userptr(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static int radeon_ttm_tt_pin_userptr(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>         struct radeon_device *rdev = radeon_get_rdev(bdev);
>         struct radeon_ttm_tt *gtt = (void *)ttm;
> @@ -408,7 +406,7 @@ static int radeon_ttm_tt_pin_userptr(struct ttm_bo_device *bdev, struct ttm_tt *
>         return r;
>  }
>
> -static void radeon_ttm_tt_unpin_userptr(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static void radeon_ttm_tt_unpin_userptr(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>         struct radeon_device *rdev = radeon_get_rdev(bdev);
>         struct radeon_ttm_tt *gtt = (void *)ttm;
> @@ -444,7 +442,7 @@ static bool radeon_ttm_backend_is_bound(struct ttm_tt *ttm)
>         return (gtt->bound);
>  }
>
> -static int radeon_ttm_backend_bind(struct ttm_bo_device *bdev,
> +static int radeon_ttm_backend_bind(struct ttm_device *bdev,
>                                    struct ttm_tt *ttm,
>                                    struct ttm_resource *bo_mem)
>  {
> @@ -480,7 +478,7 @@ static int radeon_ttm_backend_bind(struct ttm_bo_device *bdev,
>         return 0;
>  }
>
> -static void radeon_ttm_backend_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static void radeon_ttm_backend_unbind(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>         struct radeon_ttm_tt *gtt = (void *)ttm;
>         struct radeon_device *rdev = radeon_get_rdev(bdev);
> @@ -495,7 +493,7 @@ static void radeon_ttm_backend_unbind(struct ttm_bo_device *bdev, struct ttm_tt
>         gtt->bound = false;
>  }
>
> -static void radeon_ttm_backend_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static void radeon_ttm_backend_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>         struct radeon_ttm_tt *gtt = (void *)ttm;
>
> @@ -554,7 +552,7 @@ static struct radeon_ttm_tt *radeon_ttm_tt_to_gtt(struct radeon_device *rdev,
>         return container_of(ttm, struct radeon_ttm_tt, ttm);
>  }
>
> -static int radeon_ttm_tt_populate(struct ttm_bo_device *bdev,
> +static int radeon_ttm_tt_populate(struct ttm_device *bdev,
>                                   struct ttm_tt *ttm,
>                                   struct ttm_operation_ctx *ctx)
>  {
> @@ -580,7 +578,7 @@ static int radeon_ttm_tt_populate(struct ttm_bo_device *bdev,
>         return ttm_pool_alloc(&rdev->mman.bdev.pool, ttm, ctx);
>  }
>
> -static void radeon_ttm_tt_unpopulate(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static void radeon_ttm_tt_unpopulate(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>         struct radeon_device *rdev = radeon_get_rdev(bdev);
>         struct radeon_ttm_tt *gtt = radeon_ttm_tt_to_gtt(rdev, ttm);
> @@ -613,7 +611,7 @@ int radeon_ttm_tt_set_userptr(struct radeon_device *rdev,
>         return 0;
>  }
>
> -bool radeon_ttm_tt_is_bound(struct ttm_bo_device *bdev,
> +bool radeon_ttm_tt_is_bound(struct ttm_device *bdev,
>                             struct ttm_tt *ttm)
>  {
>  #if IS_ENABLED(CONFIG_AGP)
> @@ -624,7 +622,7 @@ bool radeon_ttm_tt_is_bound(struct ttm_bo_device *bdev,
>         return radeon_ttm_backend_is_bound(ttm);
>  }
>
> -static int radeon_ttm_tt_bind(struct ttm_bo_device *bdev,
> +static int radeon_ttm_tt_bind(struct ttm_device *bdev,
>                               struct ttm_tt *ttm,
>                               struct ttm_resource *bo_mem)
>  {
> @@ -642,7 +640,7 @@ static int radeon_ttm_tt_bind(struct ttm_bo_device *bdev,
>         return radeon_ttm_backend_bind(bdev, ttm, bo_mem);
>  }
>
> -static void radeon_ttm_tt_unbind(struct ttm_bo_device *bdev,
> +static void radeon_ttm_tt_unbind(struct ttm_device *bdev,
>                                  struct ttm_tt *ttm)
>  {
>  #if IS_ENABLED(CONFIG_AGP)
> @@ -656,7 +654,7 @@ static void radeon_ttm_tt_unbind(struct ttm_bo_device *bdev,
>         radeon_ttm_backend_unbind(bdev, ttm);
>  }
>
> -static void radeon_ttm_tt_destroy(struct ttm_bo_device *bdev,
> +static void radeon_ttm_tt_destroy(struct ttm_device *bdev,
>                                   struct ttm_tt *ttm)
>  {
>  #if IS_ENABLED(CONFIG_AGP)
> @@ -700,7 +698,7 @@ radeon_bo_delete_mem_notify(struct ttm_buffer_object *bo)
>         radeon_bo_move_notify(bo, false, NULL);
>  }
>
> -static struct ttm_bo_driver radeon_bo_driver = {
> +static struct ttm_device_funcs radeon_bo_driver = {
>         .ttm_tt_create = &radeon_ttm_tt_create,
>         .ttm_tt_populate = &radeon_ttm_tt_populate,
>         .ttm_tt_unpopulate = &radeon_ttm_tt_unpopulate,
> @@ -718,7 +716,7 @@ int radeon_ttm_init(struct radeon_device *rdev)
>         int r;
>
>         /* No others user of address space so set it to 0 */
> -       r = ttm_bo_device_init(&rdev->mman.bdev, &radeon_bo_driver, rdev->dev,
> +       r = ttm_device_init(&rdev->mman.bdev, &radeon_bo_driver, rdev->dev,
>                                rdev->ddev->anon_inode->i_mapping,
>                                rdev->ddev->vma_offset_manager,
>                                rdev->need_swiotlb,
> @@ -791,7 +789,7 @@ void radeon_ttm_fini(struct radeon_device *rdev)
>         }
>         ttm_range_man_fini(&rdev->mman.bdev, TTM_PL_VRAM);
>         ttm_range_man_fini(&rdev->mman.bdev, TTM_PL_TT);
> -       ttm_bo_device_release(&rdev->mman.bdev);
> +       ttm_device_fini(&rdev->mman.bdev);
>         radeon_gart_fini(rdev);
>         rdev->mman.initialized = false;
>         DRM_INFO("radeon: ttm finalized\n");
> diff --git a/drivers/gpu/drm/ttm/Makefile b/drivers/gpu/drm/ttm/Makefile
> index b6f5f87b270f..8e6437eadabe 100644
> --- a/drivers/gpu/drm/ttm/Makefile
> +++ b/drivers/gpu/drm/ttm/Makefile
> @@ -5,7 +5,7 @@
>  ttm-y := ttm_memory.o ttm_tt.o ttm_bo.o \
>         ttm_bo_util.o ttm_bo_vm.o ttm_module.o \
>         ttm_execbuf_util.o ttm_range_manager.o \
> -       ttm_resource.o ttm_pool.o
> +       ttm_resource.o ttm_pool.o ttm_device.o
>  ttm-$(CONFIG_AGP) += ttm_agp_backend.o
>
>  obj-$(CONFIG_DRM_TTM) += ttm.o
> diff --git a/drivers/gpu/drm/ttm/ttm_agp_backend.c b/drivers/gpu/drm/ttm/ttm_agp_backend.c
> index 8f9fa4188897..0226ae69d3ab 100644
> --- a/drivers/gpu/drm/ttm/ttm_agp_backend.c
> +++ b/drivers/gpu/drm/ttm/ttm_agp_backend.c
> @@ -49,7 +49,7 @@ struct ttm_agp_backend {
>  int ttm_agp_bind(struct ttm_tt *ttm, struct ttm_resource *bo_mem)
>  {
>         struct ttm_agp_backend *agp_be = container_of(ttm, struct ttm_agp_backend, ttm);
> -       struct page *dummy_read_page = ttm_bo_glob.dummy_read_page;
> +       struct page *dummy_read_page = ttm_glob.dummy_read_page;
>         struct drm_mm_node *node = bo_mem->mm_node;
>         struct agp_memory *mem;
>         int ret, cached = ttm->caching == ttm_cached;
> diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c
> index c289a6a37ff9..20256797f3a6 100644
> --- a/drivers/gpu/drm/ttm/ttm_bo.c
> +++ b/drivers/gpu/drm/ttm/ttm_bo.c
> @@ -44,14 +44,6 @@
>
>  #include "ttm_module.h"
>
> -/*
> - * ttm_global_mutex - protecting the global BO state
> - */
> -DEFINE_MUTEX(ttm_global_mutex);
> -unsigned ttm_bo_glob_use_count;
> -struct ttm_bo_global ttm_bo_glob;
> -EXPORT_SYMBOL(ttm_bo_glob);
> -
>  /* default destructor */
>  static void ttm_bo_default_destroy(struct ttm_buffer_object *bo)
>  {
> @@ -79,13 +71,13 @@ static void ttm_bo_mem_space_debug(struct ttm_buffer_object *bo,
>
>  static void ttm_bo_del_from_lru(struct ttm_buffer_object *bo)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>
>         list_del_init(&bo->swap);
>         list_del_init(&bo->lru);
>
> -       if (bdev->driver->del_from_lru_notify)
> -               bdev->driver->del_from_lru_notify(bo);
> +       if (bdev->funcs->del_from_lru_notify)
> +               bdev->funcs->del_from_lru_notify(bo);
>  }
>
>  static void ttm_bo_bulk_move_set_pos(struct ttm_lru_bulk_move_pos *pos,
> @@ -100,7 +92,7 @@ void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
>                              struct ttm_resource *mem,
>                              struct ttm_lru_bulk_move *bulk)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>         struct ttm_resource_manager *man;
>
>         dma_resv_assert_held(bo->base.resv);
> @@ -117,12 +109,12 @@ void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
>                                      TTM_PAGE_FLAG_SWAPPED))) {
>                 struct list_head *swap;
>
> -               swap = &ttm_bo_glob.swap_lru[bo->priority];
> +               swap = &ttm_glob.swap_lru[bo->priority];
>                 list_move_tail(&bo->swap, swap);
>         }
>
> -       if (bdev->driver->del_from_lru_notify)
> -               bdev->driver->del_from_lru_notify(bo);
> +       if (bdev->funcs->del_from_lru_notify)
> +               bdev->funcs->del_from_lru_notify(bo);
>
>         if (bulk && !bo->pin_count) {
>                 switch (bo->mem.mem_type) {
> @@ -185,7 +177,7 @@ void ttm_bo_bulk_move_lru_tail(struct ttm_lru_bulk_move *bulk)
>                 dma_resv_assert_held(pos->first->base.resv);
>                 dma_resv_assert_held(pos->last->base.resv);
>
> -               lru = &ttm_bo_glob.swap_lru[i];
> +               lru = &ttm_glob.swap_lru[i];
>                 list_bulk_move_tail(lru, &pos->first->swap, &pos->last->swap);
>         }
>  }
> @@ -196,7 +188,7 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
>                                   struct ttm_operation_ctx *ctx,
>                                   struct ttm_place *hop)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>         struct ttm_resource_manager *old_man = ttm_manager_type(bdev, bo->mem.mem_type);
>         struct ttm_resource_manager *new_man = ttm_manager_type(bdev, mem->mem_type);
>         int ret;
> @@ -222,7 +214,7 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
>                 }
>         }
>
> -       ret = bdev->driver->move(bo, evict, ctx, mem, hop);
> +       ret = bdev->funcs->move(bo, evict, ctx, mem, hop);
>         if (ret) {
>                 if (ret == -EMULTIHOP)
>                         return ret;
> @@ -250,8 +242,8 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
>
>  static void ttm_bo_cleanup_memtype_use(struct ttm_buffer_object *bo)
>  {
> -       if (bo->bdev->driver->delete_mem_notify)
> -               bo->bdev->driver->delete_mem_notify(bo);
> +       if (bo->bdev->funcs->delete_mem_notify)
> +               bo->bdev->funcs->delete_mem_notify(bo);
>
>         ttm_bo_tt_destroy(bo);
>         ttm_resource_free(bo, &bo->mem);
> @@ -276,9 +268,9 @@ static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
>                  * 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);
> +               spin_lock(&ttm_glob.lru_lock);
>                 bo->base.resv = &bo->base._resv;
> -               spin_unlock(&ttm_bo_glob.lru_lock);
> +               spin_unlock(&ttm_glob.lru_lock);
>         }
>
>         return r;
> @@ -337,7 +329,7 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>
>                 if (unlock_resv)
>                         dma_resv_unlock(bo->base.resv);
> -               spin_unlock(&ttm_bo_glob.lru_lock);
> +               spin_unlock(&ttm_glob.lru_lock);
>
>                 lret = dma_resv_wait_timeout_rcu(resv, true, interruptible,
>                                                  30 * HZ);
> @@ -347,7 +339,7 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>                 else if (lret == 0)
>                         return -EBUSY;
>
> -               spin_lock(&ttm_bo_glob.lru_lock);
> +               spin_lock(&ttm_glob.lru_lock);
>                 if (unlock_resv && !dma_resv_trylock(bo->base.resv)) {
>                         /*
>                          * We raced, and lost, someone else holds the reservation now,
> @@ -357,7 +349,7 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>                          * delayed destruction would succeed, so just return success
>                          * here.
>                          */
> -                       spin_unlock(&ttm_bo_glob.lru_lock);
> +                       spin_unlock(&ttm_glob.lru_lock);
>                         return 0;
>                 }
>                 ret = 0;
> @@ -366,13 +358,13 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>         if (ret || unlikely(list_empty(&bo->ddestroy))) {
>                 if (unlock_resv)
>                         dma_resv_unlock(bo->base.resv);
> -               spin_unlock(&ttm_bo_glob.lru_lock);
> +               spin_unlock(&ttm_glob.lru_lock);
>                 return ret;
>         }
>
>         ttm_bo_del_from_lru(bo);
>         list_del_init(&bo->ddestroy);
> -       spin_unlock(&ttm_bo_glob.lru_lock);
> +       spin_unlock(&ttm_glob.lru_lock);
>         ttm_bo_cleanup_memtype_use(bo);
>
>         if (unlock_resv)
> @@ -387,9 +379,9 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>   * Traverse the delayed list, and call ttm_bo_cleanup_refs on all
>   * encountered buffers.
>   */
> -static bool ttm_bo_delayed_delete(struct ttm_bo_device *bdev, bool remove_all)
> +bool ttm_bo_delayed_delete(struct ttm_device *bdev, bool remove_all)
>  {
> -       struct ttm_bo_global *glob = &ttm_bo_glob;
> +       struct ttm_global *glob = &ttm_glob;
>         struct list_head removed;
>         bool empty;
>
> @@ -428,21 +420,11 @@ static bool ttm_bo_delayed_delete(struct ttm_bo_device *bdev, bool remove_all)
>         return empty;
>  }
>
> -static void ttm_bo_delayed_workqueue(struct work_struct *work)
> -{
> -       struct ttm_bo_device *bdev =
> -           container_of(work, struct ttm_bo_device, wq.work);
> -
> -       if (!ttm_bo_delayed_delete(bdev, false))
> -               schedule_delayed_work(&bdev->wq,
> -                                     ((HZ / 100) < 1) ? 1 : HZ / 100);
> -}
> -
>  static void ttm_bo_release(struct kref *kref)
>  {
>         struct ttm_buffer_object *bo =
>             container_of(kref, struct ttm_buffer_object, kref);
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>         size_t acc_size = bo->acc_size;
>         int ret;
>
> @@ -456,8 +438,8 @@ static void ttm_bo_release(struct kref *kref)
>                                                   30 * HZ);
>                 }
>
> -               if (bo->bdev->driver->release_notify)
> -                       bo->bdev->driver->release_notify(bo);
> +               if (bo->bdev->funcs->release_notify)
> +                       bo->bdev->funcs->release_notify(bo);
>
>                 drm_vma_offset_remove(bdev->vma_manager, &bo->base.vma_node);
>                 ttm_mem_io_free(bdev, &bo->mem);
> @@ -469,7 +451,7 @@ static void ttm_bo_release(struct kref *kref)
>                 ttm_bo_flush_all_fences(bo);
>                 bo->deleted = true;
>
> -               spin_lock(&ttm_bo_glob.lru_lock);
> +               spin_lock(&ttm_glob.lru_lock);
>
>                 /*
>                  * Make pinned bos immediately available to
> @@ -483,22 +465,22 @@ static void ttm_bo_release(struct kref *kref)
>
>                 kref_init(&bo->kref);
>                 list_add_tail(&bo->ddestroy, &bdev->ddestroy);
> -               spin_unlock(&ttm_bo_glob.lru_lock);
> +               spin_unlock(&ttm_glob.lru_lock);
>
>                 schedule_delayed_work(&bdev->wq,
>                                       ((HZ / 100) < 1) ? 1 : HZ / 100);
>                 return;
>         }
>
> -       spin_lock(&ttm_bo_glob.lru_lock);
> +       spin_lock(&ttm_glob.lru_lock);
>         ttm_bo_del_from_lru(bo);
>         list_del(&bo->ddestroy);
> -       spin_unlock(&ttm_bo_glob.lru_lock);
> +       spin_unlock(&ttm_glob.lru_lock);
>
>         ttm_bo_cleanup_memtype_use(bo);
>         dma_resv_unlock(bo->base.resv);
>
> -       atomic_dec(&ttm_bo_glob.bo_count);
> +       atomic_dec(&ttm_glob.bo_count);
>         dma_fence_put(bo->moving);
>         if (!ttm_bo_uses_embedded_gem_object(bo))
>                 dma_resv_fini(&bo->base._resv);
> @@ -512,13 +494,13 @@ void ttm_bo_put(struct ttm_buffer_object *bo)
>  }
>  EXPORT_SYMBOL(ttm_bo_put);
>
> -int ttm_bo_lock_delayed_workqueue(struct ttm_bo_device *bdev)
> +int ttm_bo_lock_delayed_workqueue(struct ttm_device *bdev)
>  {
>         return cancel_delayed_work_sync(&bdev->wq);
>  }
>  EXPORT_SYMBOL(ttm_bo_lock_delayed_workqueue);
>
> -void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev, int resched)
> +void ttm_bo_unlock_delayed_workqueue(struct ttm_device *bdev, int resched)
>  {
>         if (resched)
>                 schedule_delayed_work(&bdev->wq,
> @@ -529,7 +511,7 @@ EXPORT_SYMBOL(ttm_bo_unlock_delayed_workqueue);
>  static int ttm_bo_evict(struct ttm_buffer_object *bo,
>                         struct ttm_operation_ctx *ctx)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>         struct ttm_resource evict_mem;
>         struct ttm_placement placement;
>         struct ttm_place hop;
> @@ -541,7 +523,7 @@ static int ttm_bo_evict(struct ttm_buffer_object *bo,
>
>         placement.num_placement = 0;
>         placement.num_busy_placement = 0;
> -       bdev->driver->evict_flags(bo, &placement);
> +       bdev->funcs->evict_flags(bo, &placement);
>
>         if (!placement.num_placement && !placement.num_busy_placement) {
>                 ttm_bo_wait(bo, false, false);
> @@ -657,7 +639,7 @@ static int ttm_mem_evict_wait_busy(struct ttm_buffer_object *busy_bo,
>         return r == -EDEADLK ? -EBUSY : r;
>  }
>
> -int ttm_mem_evict_first(struct ttm_bo_device *bdev,
> +int ttm_mem_evict_first(struct ttm_device *bdev,
>                         struct ttm_resource_manager *man,
>                         const struct ttm_place *place,
>                         struct ttm_operation_ctx *ctx,
> @@ -668,7 +650,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>         unsigned i;
>         int ret;
>
> -       spin_lock(&ttm_bo_glob.lru_lock);
> +       spin_lock(&ttm_glob.lru_lock);
>         for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i) {
>                 list_for_each_entry(bo, &man->lru[i], lru) {
>                         bool busy;
> @@ -681,7 +663,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>                                 continue;
>                         }
>
> -                       if (place && !bdev->driver->eviction_valuable(bo,
> +                       if (place && !bdev->funcs->eviction_valuable(bo,
>                                                                       place)) {
>                                 if (locked)
>                                         dma_resv_unlock(bo->base.resv);
> @@ -705,7 +687,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>         if (!bo) {
>                 if (busy_bo && !ttm_bo_get_unless_zero(busy_bo))
>                         busy_bo = NULL;
> -               spin_unlock(&ttm_bo_glob.lru_lock);
> +               spin_unlock(&ttm_glob.lru_lock);
>                 ret = ttm_mem_evict_wait_busy(busy_bo, ctx, ticket);
>                 if (busy_bo)
>                         ttm_bo_put(busy_bo);
> @@ -719,7 +701,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>                 return ret;
>         }
>
> -       spin_unlock(&ttm_bo_glob.lru_lock);
> +       spin_unlock(&ttm_glob.lru_lock);
>
>         ret = ttm_bo_evict(bo, ctx);
>         if (locked)
> @@ -774,7 +756,7 @@ static int ttm_bo_mem_force_space(struct ttm_buffer_object *bo,
>                                   struct ttm_resource *mem,
>                                   struct ttm_operation_ctx *ctx)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>         struct ttm_resource_manager *man = ttm_manager_type(bdev, mem->mem_type);
>         struct ww_acquire_ctx *ticket;
>         int ret;
> @@ -809,7 +791,7 @@ static int ttm_bo_mem_placement(struct ttm_buffer_object *bo,
>                                 const struct ttm_place *place,
>                                 struct ttm_resource *mem)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>         struct ttm_resource_manager *man;
>
>         man = ttm_manager_type(bdev, place->mem_type);
> @@ -819,9 +801,9 @@ static int ttm_bo_mem_placement(struct ttm_buffer_object *bo,
>         mem->mem_type = place->mem_type;
>         mem->placement = place->flags;
>
> -       spin_lock(&ttm_bo_glob.lru_lock);
> +       spin_lock(&ttm_glob.lru_lock);
>         ttm_bo_move_to_lru_tail(bo, mem, NULL);
> -       spin_unlock(&ttm_bo_glob.lru_lock);
> +       spin_unlock(&ttm_glob.lru_lock);
>
>         return 0;
>  }
> @@ -839,7 +821,7 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
>                         struct ttm_resource *mem,
>                         struct ttm_operation_ctx *ctx)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>         bool type_found = false;
>         int i, ret;
>
> @@ -1057,7 +1039,7 @@ int ttm_bo_validate(struct ttm_buffer_object *bo,
>  }
>  EXPORT_SYMBOL(ttm_bo_validate);
>
> -int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
> +int ttm_bo_init_reserved(struct ttm_device *bdev,
>                          struct ttm_buffer_object *bo,
>                          size_t size,
>                          enum ttm_bo_type type,
> @@ -1117,7 +1099,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>                 dma_resv_init(&bo->base._resv);
>                 drm_vma_node_reset(&bo->base.vma_node);
>         }
> -       atomic_inc(&ttm_bo_glob.bo_count);
> +       atomic_inc(&ttm_glob.bo_count);
>
>         /*
>          * For ttm_bo_type_device buffers, allocate
> @@ -1153,7 +1135,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>  }
>  EXPORT_SYMBOL(ttm_bo_init_reserved);
>
> -int ttm_bo_init(struct ttm_bo_device *bdev,
> +int ttm_bo_init(struct ttm_device *bdev,
>                 struct ttm_buffer_object *bo,
>                 size_t size,
>                 enum ttm_bo_type type,
> @@ -1181,7 +1163,7 @@ int ttm_bo_init(struct ttm_bo_device *bdev,
>  }
>  EXPORT_SYMBOL(ttm_bo_init);
>
> -size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
> +size_t ttm_bo_dma_acc_size(struct ttm_device *bdev,
>                            unsigned long bo_size,
>                            unsigned struct_size)
>  {
> @@ -1195,148 +1177,13 @@ size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
>  }
>  EXPORT_SYMBOL(ttm_bo_dma_acc_size);
>
> -static void ttm_bo_global_release(void)
> -{
> -       struct ttm_bo_global *glob = &ttm_bo_glob;
> -
> -       mutex_lock(&ttm_global_mutex);
> -       if (--ttm_bo_glob_use_count > 0)
> -               goto out;
> -
> -       kobject_del(&glob->kobj);
> -       kobject_put(&glob->kobj);
> -       ttm_mem_global_release(&ttm_mem_glob);
> -       __free_page(glob->dummy_read_page);
> -       memset(glob, 0, sizeof(*glob));
> -out:
> -       mutex_unlock(&ttm_global_mutex);
> -}
> -
> -static int ttm_bo_global_init(void)
> -{
> -       struct ttm_bo_global *glob = &ttm_bo_glob;
> -       int ret = 0;
> -       unsigned i;
> -
> -       mutex_lock(&ttm_global_mutex);
> -       if (++ttm_bo_glob_use_count > 1)
> -               goto out;
> -
> -       ret = ttm_mem_global_init(&ttm_mem_glob);
> -       if (ret)
> -               goto out;
> -
> -       spin_lock_init(&glob->lru_lock);
> -       glob->dummy_read_page = alloc_page(__GFP_ZERO | GFP_DMA32);
> -
> -       if (unlikely(glob->dummy_read_page == NULL)) {
> -               ret = -ENOMEM;
> -               goto out;
> -       }
> -
> -       for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
> -               INIT_LIST_HEAD(&glob->swap_lru[i]);
> -       INIT_LIST_HEAD(&glob->device_list);
> -       atomic_set(&glob->bo_count, 0);
> -
> -       debugfs_create_atomic_t("buffer_objects", 0444, ttm_debugfs_root,
> -                               &glob->bo_count);
> -out:
> -       mutex_unlock(&ttm_global_mutex);
> -       return ret;
> -}
> -
> -int ttm_bo_device_release(struct ttm_bo_device *bdev)
> -{
> -       struct ttm_bo_global *glob = &ttm_bo_glob;
> -       int ret = 0;
> -       unsigned i;
> -       struct ttm_resource_manager *man;
> -
> -       man = ttm_manager_type(bdev, TTM_PL_SYSTEM);
> -       ttm_resource_manager_set_used(man, false);
> -       ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, NULL);
> -
> -       mutex_lock(&ttm_global_mutex);
> -       list_del(&bdev->device_list);
> -       mutex_unlock(&ttm_global_mutex);
> -
> -       cancel_delayed_work_sync(&bdev->wq);
> -
> -       if (ttm_bo_delayed_delete(bdev, true))
> -               pr_debug("Delayed destroy list was clean\n");
> -
> -       spin_lock(&glob->lru_lock);
> -       for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
> -               if (list_empty(&man->lru[0]))
> -                       pr_debug("Swap list %d was clean\n", i);
> -       spin_unlock(&glob->lru_lock);
> -
> -       ttm_pool_fini(&bdev->pool);
> -
> -       if (!ret)
> -               ttm_bo_global_release();
> -
> -       return ret;
> -}
> -EXPORT_SYMBOL(ttm_bo_device_release);
> -
> -static void ttm_bo_init_sysman(struct ttm_bo_device *bdev)
> -{
> -       struct ttm_resource_manager *man = &bdev->sysman;
> -
> -       /*
> -        * Initialize the system memory buffer type.
> -        * Other types need to be driver / IOCTL initialized.
> -        */
> -       man->use_tt = true;
> -
> -       ttm_resource_manager_init(man, 0);
> -       ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, man);
> -       ttm_resource_manager_set_used(man, true);
> -}
> -
> -int ttm_bo_device_init(struct ttm_bo_device *bdev,
> -                      struct ttm_bo_driver *driver,
> -                      struct device *dev,
> -                      struct address_space *mapping,
> -                      struct drm_vma_offset_manager *vma_manager,
> -                      bool use_dma_alloc, bool use_dma32)
> -{
> -       struct ttm_bo_global *glob = &ttm_bo_glob;
> -       int ret;
> -
> -       if (WARN_ON(vma_manager == NULL))
> -               return -EINVAL;
> -
> -       ret = ttm_bo_global_init();
> -       if (ret)
> -               return ret;
> -
> -       bdev->driver = driver;
> -
> -       ttm_bo_init_sysman(bdev);
> -       ttm_pool_init(&bdev->pool, dev, use_dma_alloc, use_dma32);
> -
> -       bdev->vma_manager = vma_manager;
> -       INIT_DELAYED_WORK(&bdev->wq, ttm_bo_delayed_workqueue);
> -       INIT_LIST_HEAD(&bdev->ddestroy);
> -       bdev->dev_mapping = mapping;
> -       mutex_lock(&ttm_global_mutex);
> -       list_add_tail(&bdev->device_list, &glob->device_list);
> -       mutex_unlock(&ttm_global_mutex);
> -
> -       return 0;
> -}
> -EXPORT_SYMBOL(ttm_bo_device_init);
> -
>  /*
>   * buffer object vm functions.
>   */
>
>  void ttm_bo_unmap_virtual(struct ttm_buffer_object *bo)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>
>         drm_vma_node_unmap(&bo->base.vma_node, bdev->dev_mapping);
>         ttm_mem_io_free(bdev, &bo->mem);
> @@ -1374,7 +1221,7 @@ EXPORT_SYMBOL(ttm_bo_wait);
>   */
>  int ttm_bo_swapout(struct ttm_operation_ctx *ctx)
>  {
> -       struct ttm_bo_global *glob = &ttm_bo_glob;
> +       struct ttm_global *glob = &ttm_glob;
>         struct ttm_buffer_object *bo;
>         int ret = -EBUSY;
>         bool locked;
> @@ -1452,8 +1299,8 @@ int ttm_bo_swapout(struct ttm_operation_ctx *ctx)
>          * anyone tries to access a ttm page.
>          */
>
> -       if (bo->bdev->driver->swap_notify)
> -               bo->bdev->driver->swap_notify(bo);
> +       if (bo->bdev->funcs->swap_notify)
> +               bo->bdev->funcs->swap_notify(bo);
>
>         ret = ttm_tt_swapout(bo->bdev, bo->ttm);
>  out:
> @@ -1478,4 +1325,3 @@ void ttm_bo_tt_destroy(struct ttm_buffer_object *bo)
>         ttm_tt_destroy(bo->bdev, bo->ttm);
>         bo->ttm = NULL;
>  }
> -
> diff --git a/drivers/gpu/drm/ttm/ttm_bo_util.c b/drivers/gpu/drm/ttm/ttm_bo_util.c
> index 398d5013fc39..db0f2661d504 100644
> --- a/drivers/gpu/drm/ttm/ttm_bo_util.c
> +++ b/drivers/gpu/drm/ttm/ttm_bo_util.c
> @@ -46,33 +46,33 @@ struct ttm_transfer_obj {
>         struct ttm_buffer_object *bo;
>  };
>
> -int ttm_mem_io_reserve(struct ttm_bo_device *bdev,
> +int ttm_mem_io_reserve(struct ttm_device *bdev,
>                        struct ttm_resource *mem)
>  {
>         if (mem->bus.offset || mem->bus.addr)
>                 return 0;
>
>         mem->bus.is_iomem = false;
> -       if (!bdev->driver->io_mem_reserve)
> +       if (!bdev->funcs->io_mem_reserve)
>                 return 0;
>
> -       return bdev->driver->io_mem_reserve(bdev, mem);
> +       return bdev->funcs->io_mem_reserve(bdev, mem);
>  }
>
> -void ttm_mem_io_free(struct ttm_bo_device *bdev,
> +void ttm_mem_io_free(struct ttm_device *bdev,
>                      struct ttm_resource *mem)
>  {
>         if (!mem->bus.offset && !mem->bus.addr)
>                 return;
>
> -       if (bdev->driver->io_mem_free)
> -               bdev->driver->io_mem_free(bdev, mem);
> +       if (bdev->funcs->io_mem_free)
> +               bdev->funcs->io_mem_free(bdev, mem);
>
>         mem->bus.offset = 0;
>         mem->bus.addr = NULL;
>  }
>
> -static int ttm_resource_ioremap(struct ttm_bo_device *bdev,
> +static int ttm_resource_ioremap(struct ttm_device *bdev,
>                                struct ttm_resource *mem,
>                                void **virtual)
>  {
> @@ -102,7 +102,7 @@ static int ttm_resource_ioremap(struct ttm_bo_device *bdev,
>         return 0;
>  }
>
> -static void ttm_resource_iounmap(struct ttm_bo_device *bdev,
> +static void ttm_resource_iounmap(struct ttm_device *bdev,
>                                 struct ttm_resource *mem,
>                                 void *virtual)
>  {
> @@ -172,7 +172,7 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo,
>                        struct ttm_operation_ctx *ctx,
>                        struct ttm_resource *new_mem)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>         struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type);
>         struct ttm_tt *ttm = bo->ttm;
>         struct ttm_resource *old_mem = &bo->mem;
> @@ -300,7 +300,7 @@ static int ttm_buffer_object_transfer(struct ttm_buffer_object *bo,
>          * TODO: Explicit member copy would probably be better here.
>          */
>
> -       atomic_inc(&ttm_bo_glob.bo_count);
> +       atomic_inc(&ttm_glob.bo_count);
>         INIT_LIST_HEAD(&fbo->base.ddestroy);
>         INIT_LIST_HEAD(&fbo->base.lru);
>         INIT_LIST_HEAD(&fbo->base.swap);
> @@ -602,7 +602,7 @@ static int ttm_bo_move_to_ghost(struct ttm_buffer_object *bo,
>  static void ttm_bo_move_pipeline_evict(struct ttm_buffer_object *bo,
>                                        struct dma_fence *fence)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>         struct ttm_resource_manager *from = ttm_manager_type(bdev, bo->mem.mem_type);
>
>         /**
> @@ -628,7 +628,7 @@ int ttm_bo_move_accel_cleanup(struct ttm_buffer_object *bo,
>                               bool pipeline,
>                               struct ttm_resource *new_mem)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>         struct ttm_resource_manager *from = ttm_manager_type(bdev, bo->mem.mem_type);
>         struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type);
>         int ret = 0;
> diff --git a/drivers/gpu/drm/ttm/ttm_bo_vm.c b/drivers/gpu/drm/ttm/ttm_bo_vm.c
> index 6dc96cf66744..b31b18058965 100644
> --- a/drivers/gpu/drm/ttm/ttm_bo_vm.c
> +++ b/drivers/gpu/drm/ttm/ttm_bo_vm.c
> @@ -95,10 +95,10 @@ static vm_fault_t ttm_bo_vm_fault_idle(struct ttm_buffer_object *bo,
>  static unsigned long ttm_bo_io_mem_pfn(struct ttm_buffer_object *bo,
>                                        unsigned long page_offset)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>
> -       if (bdev->driver->io_mem_pfn)
> -               return bdev->driver->io_mem_pfn(bo, page_offset);
> +       if (bdev->funcs->io_mem_pfn)
> +               return bdev->funcs->io_mem_pfn(bo, page_offset);
>
>         return (bo->mem.bus.offset >> PAGE_SHIFT) + page_offset;
>  }
> @@ -216,7 +216,7 @@ static vm_fault_t ttm_bo_vm_insert_huge(struct vm_fault *vmf,
>                         if (page_to_pfn(ttm->pages[page_offset + i]) != pfn + i)
>                                 goto out_fallback;
>                 }
> -       } else if (bo->bdev->driver->io_mem_pfn) {
> +       } else if (bo->bdev->funcs->io_mem_pfn) {
>                 for (i = 1; i < fault_page_size; ++i) {
>                         if (ttm_bo_io_mem_pfn(bo, page_offset + i) != pfn + i)
>                                 goto out_fallback;
> @@ -278,7 +278,7 @@ vm_fault_t ttm_bo_vm_fault_reserved(struct vm_fault *vmf,
>  {
>         struct vm_area_struct *vma = vmf->vma;
>         struct ttm_buffer_object *bo = vma->vm_private_data;
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>         unsigned long page_offset;
>         unsigned long page_last;
>         unsigned long pfn;
> @@ -488,8 +488,8 @@ int ttm_bo_vm_access(struct vm_area_struct *vma, unsigned long addr,
>                 ret = ttm_bo_vm_access_kmap(bo, offset, buf, len, write);
>                 break;
>         default:
> -               if (bo->bdev->driver->access_memory)
> -                       ret = bo->bdev->driver->access_memory(
> +               if (bo->bdev->funcs->access_memory)
> +                       ret = bo->bdev->funcs->access_memory(
>                                 bo, offset, buf, len, write);
>                 else
>                         ret = -EIO;
> @@ -508,7 +508,7 @@ static const struct vm_operations_struct ttm_bo_vm_ops = {
>         .access = ttm_bo_vm_access,
>  };
>
> -static struct ttm_buffer_object *ttm_bo_vm_lookup(struct ttm_bo_device *bdev,
> +static struct ttm_buffer_object *ttm_bo_vm_lookup(struct ttm_device *bdev,
>                                                   unsigned long offset,
>                                                   unsigned long pages)
>  {
> @@ -555,9 +555,8 @@ static void ttm_bo_mmap_vma_setup(struct ttm_buffer_object *bo, struct vm_area_s
>  }
>
>  int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
> -               struct ttm_bo_device *bdev)
> +               struct ttm_device *bdev)
>  {
> -       struct ttm_bo_driver *driver;
>         struct ttm_buffer_object *bo;
>         int ret;
>
> @@ -568,12 +567,11 @@ int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
>         if (unlikely(!bo))
>                 return -EINVAL;
>
> -       driver = bo->bdev->driver;
> -       if (unlikely(!driver->verify_access)) {
> +       if (unlikely(!bo->bdev->funcs->verify_access)) {
>                 ret = -EPERM;
>                 goto out_unref;
>         }
> -       ret = driver->verify_access(bo, filp);
> +       ret = bo->bdev->funcs->verify_access(bo, filp);
>         if (unlikely(ret != 0))
>                 goto out_unref;
>
> diff --git a/drivers/gpu/drm/ttm/ttm_device.c b/drivers/gpu/drm/ttm/ttm_device.c
> new file mode 100644
> index 000000000000..ac0903c9e60a
> --- /dev/null
> +++ b/drivers/gpu/drm/ttm/ttm_device.c
> @@ -0,0 +1,195 @@
> +/* SPDX-License-Identifier: GPL-2.0 OR MIT */
> +
> +/*
> + * Copyright (c) 2006-2009 VMware, Inc., Palo Alto, CA., USA
> + * Copyright 2020 Advanced Micro Devices, Inc.
> + *
> + * Permission is hereby granted, free of charge, to any person obtaining a
> + * copy of this software and associated documentation files (the "Software"),
> + * to deal in the Software without restriction, including without limitation
> + * the rights to use, copy, modify, merge, publish, distribute, sublicense,
> + * and/or sell copies of the Software, and to permit persons to whom the
> + * Software is furnished to do so, subject to the following conditions:
> + *
> + * The above copyright notice and this permission notice shall be included in
> + * all copies or substantial portions of the Software.
> + *
> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
> + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
> + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
> + * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
> + * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
> + * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
> + * OTHER DEALINGS IN THE SOFTWARE.
> + *
> + * Authors: Christian König
> + */
> +
> +#define pr_fmt(fmt) "[TTM DEVICE] " fmt
> +
> +#include <drm/ttm/ttm_device.h>
> +#include <drm/ttm/ttm_memory.h>
> +#include <drm/ttm/ttm_placement.h>
> +
> +#include "ttm_module.h"
> +
> +/**
> + * ttm_global_mutex - protecting the global state
> + */
> +DEFINE_MUTEX(ttm_global_mutex);
> +unsigned ttm_glob_use_count;
> +struct ttm_global ttm_glob;
> +EXPORT_SYMBOL(ttm_glob);
> +
> +static void ttm_global_release(void)
> +{
> +       struct ttm_global *glob = &ttm_glob;
> +
> +       mutex_lock(&ttm_global_mutex);
> +       if (--ttm_glob_use_count > 0)
> +               goto out;
> +
> +       kobject_del(&glob->kobj);
> +       kobject_put(&glob->kobj);
> +       ttm_mem_global_release(&ttm_mem_glob);
> +       __free_page(glob->dummy_read_page);
> +       memset(glob, 0, sizeof(*glob));
> +out:
> +       mutex_unlock(&ttm_global_mutex);
> +}
> +
> +static int ttm_global_init(void)
> +{
> +       struct ttm_global *glob = &ttm_glob;
> +       int ret = 0;
> +       unsigned i;
> +
> +       mutex_lock(&ttm_global_mutex);
> +       if (++ttm_glob_use_count > 1)
> +               goto out;
> +
> +       ret = ttm_mem_global_init(&ttm_mem_glob);
> +       if (ret)
> +               goto out;
> +
> +       spin_lock_init(&glob->lru_lock);
> +       glob->dummy_read_page = alloc_page(__GFP_ZERO | GFP_DMA32);
> +
> +       if (unlikely(glob->dummy_read_page == NULL)) {
> +               ret = -ENOMEM;
> +               goto out;
> +       }
> +
> +       for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
> +               INIT_LIST_HEAD(&glob->swap_lru[i]);
> +       INIT_LIST_HEAD(&glob->device_list);
> +       atomic_set(&glob->bo_count, 0);
> +
> +       debugfs_create_atomic_t("buffer_objects", 0444, ttm_debugfs_root,
> +                               &glob->bo_count);
> +out:
> +       mutex_unlock(&ttm_global_mutex);
> +       return ret;
> +}
> +
> +static void ttm_init_sysman(struct ttm_device *bdev)
> +{
> +       struct ttm_resource_manager *man = &bdev->sysman;
> +
> +       /*
> +        * Initialize the system memory buffer type.
> +        * Other types need to be driver / IOCTL initialized.
> +        */
> +       man->use_tt = true;
> +
> +       ttm_resource_manager_init(man, 0);
> +       ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, man);
> +       ttm_resource_manager_set_used(man, true);
> +}
> +
> +static void ttm_device_delayed_workqueue(struct work_struct *work)
> +{
> +       struct ttm_device *bdev =
> +               container_of(work, struct ttm_device, wq.work);
> +
> +       if (!ttm_bo_delayed_delete(bdev, false))
> +               schedule_delayed_work(&bdev->wq,
> +                                     ((HZ / 100) < 1) ? 1 : HZ / 100);
> +}
> +
> +/**
> + * ttm_device_init
> + *
> + * @bdev: A pointer to a struct ttm_device to initialize.
> + * @funcs: Function table for the device.
> + * @dev: The core kernel device pointer for DMA mappings and allocations.
> + * @mapping: The address space to use for this bo.
> + * @vma_manager: A pointer to a vma manager.
> + * @use_dma_alloc: If coherent DMA allocation API should be used.
> + * @use_dma32: If we should use GFP_DMA32 for device memory allocations.
> + *
> + * Initializes a struct ttm_device:
> + * Returns:
> + * !0: Failure.
> + */
> +int ttm_device_init(struct ttm_device *bdev, struct ttm_device_funcs *funcs,
> +                   struct device *dev, struct address_space *mapping,
> +                   struct drm_vma_offset_manager *vma_manager,
> +                   bool use_dma_alloc, bool use_dma32)
> +{
> +       struct ttm_global *glob = &ttm_glob;
> +       int ret;
> +
> +       if (WARN_ON(vma_manager == NULL))
> +               return -EINVAL;
> +
> +       ret = ttm_global_init();
> +       if (ret)
> +               return ret;
> +
> +       bdev->funcs = funcs;
> +
> +       ttm_init_sysman(bdev);
> +       ttm_pool_init(&bdev->pool, dev, use_dma_alloc, use_dma32);
> +
> +       bdev->vma_manager = vma_manager;
> +       INIT_DELAYED_WORK(&bdev->wq, ttm_device_delayed_workqueue);
> +       INIT_LIST_HEAD(&bdev->ddestroy);
> +       bdev->dev_mapping = mapping;
> +       mutex_lock(&ttm_global_mutex);
> +       list_add_tail(&bdev->device_list, &glob->device_list);
> +       mutex_unlock(&ttm_global_mutex);
> +
> +       return 0;
> +}
> +EXPORT_SYMBOL(ttm_device_init);
> +
> +void ttm_device_fini(struct ttm_device *bdev)
> +{
> +       struct ttm_global *glob = &ttm_glob;
> +       struct ttm_resource_manager *man;
> +       unsigned i;
> +
> +       man = ttm_manager_type(bdev, TTM_PL_SYSTEM);
> +       ttm_resource_manager_set_used(man, false);
> +       ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, NULL);
> +
> +       mutex_lock(&ttm_global_mutex);
> +       list_del(&bdev->device_list);
> +       mutex_unlock(&ttm_global_mutex);
> +
> +       cancel_delayed_work_sync(&bdev->wq);
> +
> +       if (ttm_bo_delayed_delete(bdev, true))
> +               pr_debug("Delayed destroy list was clean\n");
> +
> +       spin_lock(&glob->lru_lock);
> +       for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
> +               if (list_empty(&man->lru[0]))
> +                       pr_debug("Swap list %d was clean\n", i);
> +       spin_unlock(&glob->lru_lock);
> +
> +       ttm_pool_fini(&bdev->pool);
> +       ttm_global_release();
> +}
> +EXPORT_SYMBOL(ttm_device_fini);
> diff --git a/drivers/gpu/drm/ttm/ttm_execbuf_util.c b/drivers/gpu/drm/ttm/ttm_execbuf_util.c
> index 9fa36ed59429..690ab97d52b7 100644
> --- a/drivers/gpu/drm/ttm/ttm_execbuf_util.c
> +++ b/drivers/gpu/drm/ttm/ttm_execbuf_util.c
> @@ -51,14 +51,14 @@ void ttm_eu_backoff_reservation(struct ww_acquire_ctx *ticket,
>         if (list_empty(list))
>                 return;
>
> -       spin_lock(&ttm_bo_glob.lru_lock);
> +       spin_lock(&ttm_glob.lru_lock);
>         list_for_each_entry(entry, list, head) {
>                 struct ttm_buffer_object *bo = entry->bo;
>
>                 ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
>                 dma_resv_unlock(bo->base.resv);
>         }
> -       spin_unlock(&ttm_bo_glob.lru_lock);
> +       spin_unlock(&ttm_glob.lru_lock);
>
>         if (ticket)
>                 ww_acquire_fini(ticket);
> @@ -154,7 +154,7 @@ void ttm_eu_fence_buffer_objects(struct ww_acquire_ctx *ticket,
>         if (list_empty(list))
>                 return;
>
> -       spin_lock(&ttm_bo_glob.lru_lock);
> +       spin_lock(&ttm_glob.lru_lock);
>         list_for_each_entry(entry, list, head) {
>                 struct ttm_buffer_object *bo = entry->bo;
>
> @@ -165,7 +165,7 @@ void ttm_eu_fence_buffer_objects(struct ww_acquire_ctx *ticket,
>                 ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
>                 dma_resv_unlock(bo->base.resv);
>         }
> -       spin_unlock(&ttm_bo_glob.lru_lock);
> +       spin_unlock(&ttm_glob.lru_lock);
>         if (ticket)
>                 ww_acquire_fini(ticket);
>  }
> diff --git a/drivers/gpu/drm/ttm/ttm_range_manager.c b/drivers/gpu/drm/ttm/ttm_range_manager.c
> index a39305f742da..707e5c152896 100644
> --- a/drivers/gpu/drm/ttm/ttm_range_manager.c
> +++ b/drivers/gpu/drm/ttm/ttm_range_manager.c
> @@ -111,7 +111,7 @@ static void ttm_range_man_free(struct ttm_resource_manager *man,
>
>  static const struct ttm_resource_manager_func ttm_range_manager_func;
>
> -int ttm_range_man_init(struct ttm_bo_device *bdev,
> +int ttm_range_man_init(struct ttm_device *bdev,
>                        unsigned type, bool use_tt,
>                        unsigned long p_size)
>  {
> @@ -138,7 +138,7 @@ int ttm_range_man_init(struct ttm_bo_device *bdev,
>  }
>  EXPORT_SYMBOL(ttm_range_man_init);
>
> -int ttm_range_man_fini(struct ttm_bo_device *bdev,
> +int ttm_range_man_fini(struct ttm_device *bdev,
>                        unsigned type)
>  {
>         struct ttm_resource_manager *man = ttm_manager_type(bdev, type);
> diff --git a/drivers/gpu/drm/ttm/ttm_resource.c b/drivers/gpu/drm/ttm/ttm_resource.c
> index b60699bf4816..ed1672a9f332 100644
> --- a/drivers/gpu/drm/ttm/ttm_resource.c
> +++ b/drivers/gpu/drm/ttm/ttm_resource.c
> @@ -83,7 +83,7 @@ EXPORT_SYMBOL(ttm_resource_manager_init);
>   * Evict all the objects out of a memory manager until it is empty.
>   * Part of memory manager cleanup sequence.
>   */
> -int ttm_resource_manager_evict_all(struct ttm_bo_device *bdev,
> +int ttm_resource_manager_evict_all(struct ttm_device *bdev,
>                                    struct ttm_resource_manager *man)
>  {
>         struct ttm_operation_ctx ctx = {
> @@ -91,7 +91,7 @@ int ttm_resource_manager_evict_all(struct ttm_bo_device *bdev,
>                 .no_wait_gpu = false,
>                 .force_alloc = true
>         };
> -       struct ttm_bo_global *glob = &ttm_bo_glob;
> +       struct ttm_global *glob = &ttm_glob;
>         struct dma_fence *fence;
>         int ret;
>         unsigned i;
> diff --git a/drivers/gpu/drm/ttm/ttm_tt.c b/drivers/gpu/drm/ttm/ttm_tt.c
> index 7f75a13163f0..7782d5393c7c 100644
> --- a/drivers/gpu/drm/ttm/ttm_tt.c
> +++ b/drivers/gpu/drm/ttm/ttm_tt.c
> @@ -43,7 +43,7 @@
>   */
>  int ttm_tt_create(struct ttm_buffer_object *bo, bool zero_alloc)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>         uint32_t page_flags = 0;
>
>         dma_resv_assert_held(bo->base.resv);
> @@ -66,7 +66,7 @@ int ttm_tt_create(struct ttm_buffer_object *bo, bool zero_alloc)
>                 return -EINVAL;
>         }
>
> -       bo->ttm = bdev->driver->ttm_tt_create(bo, page_flags);
> +       bo->ttm = bdev->funcs->ttm_tt_create(bo, page_flags);
>         if (unlikely(bo->ttm == NULL))
>                 return -ENOMEM;
>
> @@ -108,7 +108,7 @@ static int ttm_sg_tt_alloc_page_directory(struct ttm_tt *ttm)
>         return 0;
>  }
>
> -void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +void ttm_tt_destroy_common(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>         ttm_tt_unpopulate(bdev, ttm);
>
> @@ -119,9 +119,9 @@ void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>  }
>  EXPORT_SYMBOL(ttm_tt_destroy_common);
>
> -void ttm_tt_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +void ttm_tt_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
> -       bdev->driver->ttm_tt_destroy(bdev, ttm);
> +       bdev->funcs->ttm_tt_destroy(bdev, ttm);
>  }
>
>  static void ttm_tt_init_fields(struct ttm_tt *ttm,
> @@ -223,7 +223,7 @@ int ttm_tt_swapin(struct ttm_tt *ttm)
>         return ret;
>  }
>
> -int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +int ttm_tt_swapout(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>         struct address_space *swap_space;
>         struct file *swap_storage;
> @@ -271,7 +271,7 @@ int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>         return ret;
>  }
>
> -static void ttm_tt_add_mapping(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static void ttm_tt_add_mapping(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>         pgoff_t i;
>
> @@ -282,7 +282,7 @@ static void ttm_tt_add_mapping(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>                 ttm->pages[i]->mapping = bdev->dev_mapping;
>  }
>
> -int ttm_tt_populate(struct ttm_bo_device *bdev,
> +int ttm_tt_populate(struct ttm_device *bdev,
>                     struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)
>  {
>         int ret;
> @@ -293,8 +293,8 @@ int ttm_tt_populate(struct ttm_bo_device *bdev,
>         if (ttm_tt_is_populated(ttm))
>                 return 0;
>
> -       if (bdev->driver->ttm_tt_populate)
> -               ret = bdev->driver->ttm_tt_populate(bdev, ttm, ctx);
> +       if (bdev->funcs->ttm_tt_populate)
> +               ret = bdev->funcs->ttm_tt_populate(bdev, ttm, ctx);
>         else
>                 ret = ttm_pool_alloc(&bdev->pool, ttm, ctx);
>         if (ret)
> @@ -328,15 +328,15 @@ static void ttm_tt_clear_mapping(struct ttm_tt *ttm)
>         }
>  }
>
> -void ttm_tt_unpopulate(struct ttm_bo_device *bdev,
> +void ttm_tt_unpopulate(struct ttm_device *bdev,
>                        struct ttm_tt *ttm)
>  {
>         if (!ttm_tt_is_populated(ttm))
>                 return;
>
>         ttm_tt_clear_mapping(ttm);
> -       if (bdev->driver->ttm_tt_unpopulate)
> -               bdev->driver->ttm_tt_unpopulate(bdev, ttm);
> +       if (bdev->funcs->ttm_tt_unpopulate)
> +               bdev->funcs->ttm_tt_unpopulate(bdev, ttm);
>         else
>                 ttm_pool_free(&bdev->pool, ttm);
>         ttm->page_flags &= ~TTM_PAGE_FLAG_PRIV_POPULATED;
> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c b/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c
> index 118db24eb756..3a438ae4d3f4 100644
> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c
> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c
> @@ -466,13 +466,13 @@ int vmw_bo_cpu_blit(struct ttm_buffer_object *dst,
>                 dma_resv_assert_held(src->base.resv);
>
>         if (!ttm_tt_is_populated(dst->ttm)) {
> -               ret = dst->bdev->driver->ttm_tt_populate(dst->bdev, dst->ttm, &ctx);
> +               ret = dst->bdev->funcs->ttm_tt_populate(dst->bdev, dst->ttm, &ctx);
>                 if (ret)
>                         return ret;
>         }
>
>         if (!ttm_tt_is_populated(src->ttm)) {
> -               ret = src->bdev->driver->ttm_tt_populate(src->bdev, src->ttm, &ctx);
> +               ret = src->bdev->funcs->ttm_tt_populate(src->bdev, src->ttm, &ctx);
>                 if (ret)
>                         return ret;
>         }
> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c b/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
> index ab0844b47d4d..6b3bfd8c678a 100644
> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
> @@ -545,7 +545,7 @@ int vmw_bo_init(struct vmw_private *dev_priv,
>                 void (*bo_free)(struct ttm_buffer_object *bo))
>  {
>         struct ttm_operation_ctx ctx = { interruptible, false };
> -       struct ttm_bo_device *bdev = &dev_priv->bdev;
> +       struct ttm_device *bdev = &dev_priv->bdev;
>         size_t acc_size;
>         int ret;
>         bool user = (bo_free == &vmw_user_bo_destroy);
> @@ -1058,7 +1058,7 @@ int vmw_user_bo_reference(struct ttm_object_file *tfile,
>  void vmw_bo_fence_single(struct ttm_buffer_object *bo,
>                          struct vmw_fence_obj *fence)
>  {
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>
>         struct vmw_private *dev_priv =
>                 container_of(bdev, struct vmw_private, bdev);
> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
> index eb997f4678de..b454d80c273e 100644
> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
> @@ -884,12 +884,12 @@ static int vmw_driver_load(struct vmw_private *dev_priv, u32 pci_id)
>         drm_vma_offset_manager_init(&dev_priv->vma_manager,
>                                     DRM_FILE_PAGE_OFFSET_START,
>                                     DRM_FILE_PAGE_OFFSET_SIZE);
> -       ret = ttm_bo_device_init(&dev_priv->bdev, &vmw_bo_driver,
> -                                dev_priv->drm.dev,
> -                                dev_priv->drm.anon_inode->i_mapping,
> -                                &dev_priv->vma_manager,
> -                                dev_priv->map_mode == vmw_dma_alloc_coherent,
> -                                false);
> +       ret = ttm_device_init(&dev_priv->bdev, &vmw_bo_driver,
> +                             dev_priv->drm.dev,
> +                             dev_priv->drm.anon_inode->i_mapping,
> +                             &dev_priv->vma_manager,
> +                             dev_priv->map_mode == vmw_dma_alloc_coherent,
> +                             false);
>         if (unlikely(ret != 0)) {
>                 DRM_ERROR("Failed initializing TTM buffer object driver.\n");
>                 goto out_no_bdev;
> @@ -1006,7 +1006,7 @@ static int vmw_driver_load(struct vmw_private *dev_priv, u32 pci_id)
>                 vmw_gmrid_man_fini(dev_priv, VMW_PL_GMR);
>         vmw_vram_manager_fini(dev_priv);
>  out_no_vram:
> -       (void)ttm_bo_device_release(&dev_priv->bdev);
> +       ttm_device_fini(&dev_priv->bdev);
>  out_no_bdev:
>         vmw_fence_manager_takedown(dev_priv->fman);
>  out_no_fman:
> @@ -1053,7 +1053,7 @@ static void vmw_driver_unload(struct drm_device *dev)
>         if (dev_priv->has_mob)
>                 vmw_gmrid_man_fini(dev_priv, VMW_PL_MOB);
>         vmw_vram_manager_fini(dev_priv);
> -       (void) ttm_bo_device_release(&dev_priv->bdev);
> +       ttm_device_fini(&dev_priv->bdev);
>         drm_vma_offset_manager_destroy(&dev_priv->vma_manager);
>         vmw_release_device_late(dev_priv);
>         vmw_fence_manager_takedown(dev_priv->fman);
> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
> index 336f5086ca26..e65b00f8336d 100644
> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
> @@ -484,7 +484,7 @@ enum vmw_sm_type {
>
>  struct vmw_private {
>         struct drm_device drm;
> -       struct ttm_bo_device bdev;
> +       struct ttm_device bdev;
>
>         struct vmw_fifo_state fifo;
>
> @@ -999,7 +999,7 @@ extern struct ttm_placement vmw_evictable_placement;
>  extern struct ttm_placement vmw_srf_placement;
>  extern struct ttm_placement vmw_mob_placement;
>  extern struct ttm_placement vmw_nonfixed_placement;
> -extern struct ttm_bo_driver vmw_bo_driver;
> +extern struct ttm_device_funcs vmw_bo_driver;
>  extern const struct vmw_sg_table *
>  vmw_bo_sg_table(struct ttm_buffer_object *bo);
>  extern int vmw_bo_create_and_populate(struct vmw_private *dev_priv,
> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c b/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c
> index c4df51a2a926..c3a724e37104 100644
> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c
> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c
> @@ -856,7 +856,7 @@ void vmw_query_move_notify(struct ttm_buffer_object *bo,
>                            struct ttm_resource *mem)
>  {
>         struct vmw_buffer_object *dx_query_mob;
> -       struct ttm_bo_device *bdev = bo->bdev;
> +       struct ttm_device *bdev = bo->bdev;
>         struct vmw_private *dev_priv;
>
>
> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c b/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c
> index 6a44567e4ba5..d1bfa59579f1 100644
> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c
> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c
> @@ -483,7 +483,7 @@ const struct vmw_sg_table *vmw_bo_sg_table(struct ttm_buffer_object *bo)
>  }
>
>
> -static int vmw_ttm_bind(struct ttm_bo_device *bdev,
> +static int vmw_ttm_bind(struct ttm_device *bdev,
>                         struct ttm_tt *ttm, struct ttm_resource *bo_mem)
>  {
>         struct vmw_ttm_tt *vmw_be =
> @@ -527,7 +527,7 @@ static int vmw_ttm_bind(struct ttm_bo_device *bdev,
>         return ret;
>  }
>
> -static void vmw_ttm_unbind(struct ttm_bo_device *bdev,
> +static void vmw_ttm_unbind(struct ttm_device *bdev,
>                            struct ttm_tt *ttm)
>  {
>         struct vmw_ttm_tt *vmw_be =
> @@ -553,7 +553,7 @@ static void vmw_ttm_unbind(struct ttm_bo_device *bdev,
>  }
>
>
> -static void vmw_ttm_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static void vmw_ttm_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>         struct vmw_ttm_tt *vmw_be =
>                 container_of(ttm, struct vmw_ttm_tt, dma_ttm);
> @@ -573,7 +573,7 @@ static void vmw_ttm_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>  }
>
>
> -static int vmw_ttm_populate(struct ttm_bo_device *bdev,
> +static int vmw_ttm_populate(struct ttm_device *bdev,
>                             struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)
>  {
>         /* TODO: maybe completely drop this ? */
> @@ -583,7 +583,7 @@ static int vmw_ttm_populate(struct ttm_bo_device *bdev,
>         return ttm_pool_alloc(&bdev->pool, ttm, ctx);
>  }
>
> -static void vmw_ttm_unpopulate(struct ttm_bo_device *bdev,
> +static void vmw_ttm_unpopulate(struct ttm_device *bdev,
>                                struct ttm_tt *ttm)
>  {
>         struct vmw_ttm_tt *vmw_tt = container_of(ttm, struct vmw_ttm_tt,
> @@ -640,7 +640,7 @@ static int vmw_verify_access(struct ttm_buffer_object *bo, struct file *filp)
>         return vmw_user_bo_verify_access(bo, tfile);
>  }
>
> -static int vmw_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *mem)
> +static int vmw_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *mem)
>  {
>         struct vmw_private *dev_priv = container_of(bdev, struct vmw_private, bdev);
>
> @@ -744,7 +744,7 @@ vmw_delete_mem_notify(struct ttm_buffer_object *bo)
>         vmw_move_notify(bo, false, NULL);
>  }
>
> -struct ttm_bo_driver vmw_bo_driver = {
> +struct ttm_device_funcs vmw_bo_driver = {
>         .ttm_tt_create = &vmw_ttm_tt_create,
>         .ttm_tt_populate = &vmw_ttm_populate,
>         .ttm_tt_unpopulate = &vmw_ttm_unpopulate,
> diff --git a/include/drm/drm_gem_vram_helper.h b/include/drm/drm_gem_vram_helper.h
> index a4bac02249c2..288055d397d9 100644
> --- a/include/drm/drm_gem_vram_helper.h
> +++ b/include/drm/drm_gem_vram_helper.h
> @@ -172,19 +172,19 @@ struct drm_vram_mm {
>         uint64_t vram_base;
>         size_t vram_size;
>
> -       struct ttm_bo_device bdev;
> +       struct ttm_device bdev;
>  };
>
>  /**
>   * drm_vram_mm_of_bdev() - \
> -       Returns the container of type &struct ttm_bo_device for field bdev.
> +       Returns the container of type &struct ttm_device for field bdev.
>   * @bdev:      the TTM BO device
>   *
>   * Returns:
>   * The containing instance of &struct drm_vram_mm
>   */
>  static inline struct drm_vram_mm *drm_vram_mm_of_bdev(
> -       struct ttm_bo_device *bdev)
> +       struct ttm_device *bdev)
>  {
>         return container_of(bdev, struct drm_vram_mm, bdev);
>  }
> diff --git a/include/drm/ttm/ttm_bo_api.h b/include/drm/ttm/ttm_bo_api.h
> index e17be324d95f..62734db0b421 100644
> --- a/include/drm/ttm/ttm_bo_api.h
> +++ b/include/drm/ttm/ttm_bo_api.h
> @@ -44,9 +44,9 @@
>
>  #include "ttm_resource.h"
>
> -struct ttm_bo_global;
> +struct ttm_global;
>
> -struct ttm_bo_device;
> +struct ttm_device;
>
>  struct dma_buf_map;
>
> @@ -122,7 +122,7 @@ struct ttm_buffer_object {
>          * Members constant at init.
>          */
>
> -       struct ttm_bo_device *bdev;
> +       struct ttm_device *bdev;
>         enum ttm_bo_type type;
>         void (*destroy) (struct ttm_buffer_object *);
>         size_t acc_size;
> @@ -313,7 +313,7 @@ void ttm_bo_put(struct ttm_buffer_object *bo);
>   * @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
> + * object. This function must be called with struct ttm_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,
> @@ -326,7 +326,7 @@ void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
>   * @bulk: bulk move structure
>   *
>   * Bulk move BOs to the LRU tail, only valid to use when driver makes sure that
> - * BO order never changes. Should be called with ttm_bo_global::lru_lock held.
> + * BO order never changes. Should be called with ttm_global::lru_lock held.
>   */
>  void ttm_bo_bulk_move_lru_tail(struct ttm_lru_bulk_move *bulk);
>
> @@ -337,14 +337,14 @@ void ttm_bo_bulk_move_lru_tail(struct ttm_lru_bulk_move *bulk);
>   * Returns
>   * True if the workqueue was queued at the time
>   */
> -int ttm_bo_lock_delayed_workqueue(struct ttm_bo_device *bdev);
> +int ttm_bo_lock_delayed_workqueue(struct ttm_device *bdev);
>
>  /**
>   * ttm_bo_unlock_delayed_workqueue
>   *
>   * Allows the delayed workqueue to run.
>   */
> -void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev, int resched);
> +void ttm_bo_unlock_delayed_workqueue(struct ttm_device *bdev, int resched);
>
>  /**
>   * ttm_bo_eviction_valuable
> @@ -357,14 +357,14 @@ void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev, int resched);
>  bool ttm_bo_eviction_valuable(struct ttm_buffer_object *bo,
>                               const struct ttm_place *place);
>
> -size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
> +size_t ttm_bo_dma_acc_size(struct ttm_device *bdev,
>                            unsigned long bo_size,
>                            unsigned struct_size);
>
>  /**
>   * ttm_bo_init_reserved
>   *
> - * @bdev: Pointer to a ttm_bo_device struct.
> + * @bdev: Pointer to a ttm_device struct.
>   * @bo: Pointer to a ttm_buffer_object to be initialized.
>   * @size: Requested size of buffer object.
>   * @type: Requested type of buffer object.
> @@ -396,7 +396,7 @@ size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
>   * -ERESTARTSYS: Interrupted by signal while sleeping waiting for resources.
>   */
>
> -int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
> +int ttm_bo_init_reserved(struct ttm_device *bdev,
>                          struct ttm_buffer_object *bo,
>                          size_t size, enum ttm_bo_type type,
>                          struct ttm_placement *placement,
> @@ -409,7 +409,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>  /**
>   * ttm_bo_init
>   *
> - * @bdev: Pointer to a ttm_bo_device struct.
> + * @bdev: Pointer to a ttm_device struct.
>   * @bo: Pointer to a ttm_buffer_object to be initialized.
>   * @size: Requested size of buffer object.
>   * @type: Requested type of buffer object.
> @@ -443,7 +443,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>   * -EINVAL: Invalid placement flags.
>   * -ERESTARTSYS: Interrupted by signal while sleeping waiting for resources.
>   */
> -int ttm_bo_init(struct ttm_bo_device *bdev, struct ttm_buffer_object *bo,
> +int ttm_bo_init(struct ttm_device *bdev, struct ttm_buffer_object *bo,
>                 size_t size, enum ttm_bo_type type,
>                 struct ttm_placement *placement,
>                 uint32_t page_alignment, bool interrubtible, size_t acc_size,
> @@ -537,18 +537,18 @@ int ttm_bo_mmap_obj(struct vm_area_struct *vma, struct ttm_buffer_object *bo);
>   *
>   * @filp:      filp as input from the mmap method.
>   * @vma:       vma as input from the mmap method.
> - * @bdev:      Pointer to the ttm_bo_device with the address space manager.
> + * @bdev:      Pointer to the ttm_device with the address space manager.
>   *
>   * This function is intended to be called by the device mmap method.
>   * if the device address space is to be backed by the bo manager.
>   */
>  int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
> -               struct ttm_bo_device *bdev);
> +               struct ttm_device *bdev);
>
>  /**
>   * ttm_bo_io
>   *
> - * @bdev:      Pointer to the struct ttm_bo_device.
> + * @bdev:      Pointer to the struct ttm_device.
>   * @filp:      Pointer to the struct file attempting to read / write.
>   * @wbuf:      User-space pointer to address of buffer to write. NULL on read.
>   * @rbuf:      User-space pointer to address of buffer to read into.
> @@ -565,7 +565,7 @@ int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
>   * the function may return -ERESTARTSYS if
>   * interrupted by a signal.
>   */
> -ssize_t ttm_bo_io(struct ttm_bo_device *bdev, struct file *filp,
> +ssize_t ttm_bo_io(struct ttm_device *bdev, struct file *filp,
>                   const char __user *wbuf, char __user *rbuf,
>                   size_t count, loff_t *f_pos, bool write);
>
> @@ -617,7 +617,7 @@ static inline void ttm_bo_unpin(struct ttm_buffer_object *bo)
>         --bo->pin_count;
>  }
>
> -int ttm_mem_evict_first(struct ttm_bo_device *bdev,
> +int ttm_mem_evict_first(struct ttm_device *bdev,
>                         struct ttm_resource_manager *man,
>                         const struct ttm_place *place,
>                         struct ttm_operation_ctx *ctx,
> @@ -642,5 +642,6 @@ void ttm_bo_vm_close(struct vm_area_struct *vma);
>
>  int ttm_bo_vm_access(struct vm_area_struct *vma, unsigned long addr,
>                      void *buf, int len, int write);
> +bool ttm_bo_delayed_delete(struct ttm_device *bdev, bool remove_all);
>
>  #endif
> diff --git a/include/drm/ttm/ttm_bo_driver.h b/include/drm/ttm/ttm_bo_driver.h
> index 423348414c59..1c9bf993e252 100644
> --- a/include/drm/ttm/ttm_bo_driver.h
> +++ b/include/drm/ttm/ttm_bo_driver.h
> @@ -37,301 +37,14 @@
>  #include <linux/spinlock.h>
>  #include <linux/dma-resv.h>
>
> +#include <drm/ttm/ttm_device.h>
> +
>  #include "ttm_bo_api.h"
>  #include "ttm_memory.h"
>  #include "ttm_placement.h"
>  #include "ttm_tt.h"
>  #include "ttm_pool.h"
>
> -/**
> - * struct ttm_bo_driver
> - *
> - * @create_ttm_backend_entry: Callback to create a struct ttm_backend.
> - * @evict_flags: Callback to obtain placement flags when a buffer is evicted.
> - * @move: Callback for a driver to hook in accelerated functions to
> - * move a buffer.
> - * If set to NULL, a potentially slow memcpy() move is used.
> - */
> -
> -struct ttm_bo_driver {
> -       /**
> -        * ttm_tt_create
> -        *
> -        * @bo: The buffer object to create the ttm for.
> -        * @page_flags: Page flags as identified by TTM_PAGE_FLAG_XX flags.
> -        *
> -        * Create a struct ttm_tt to back data with system memory pages.
> -        * No pages are actually allocated.
> -        * Returns:
> -        * NULL: Out of memory.
> -        */
> -       struct ttm_tt *(*ttm_tt_create)(struct ttm_buffer_object *bo,
> -                                       uint32_t page_flags);
> -
> -       /**
> -        * ttm_tt_populate
> -        *
> -        * @ttm: The struct ttm_tt to contain the backing pages.
> -        *
> -        * Allocate all backing pages
> -        * Returns:
> -        * -ENOMEM: Out of memory.
> -        */
> -       int (*ttm_tt_populate)(struct ttm_bo_device *bdev,
> -                              struct ttm_tt *ttm,
> -                              struct ttm_operation_ctx *ctx);
> -
> -       /**
> -        * ttm_tt_unpopulate
> -        *
> -        * @ttm: The struct ttm_tt to contain the backing pages.
> -        *
> -        * Free all backing page
> -        */
> -       void (*ttm_tt_unpopulate)(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> -
> -       /**
> -        * ttm_tt_destroy
> -        *
> -        * @bdev: Pointer to a ttm device
> -        * @ttm: Pointer to a struct ttm_tt.
> -        *
> -        * Destroy the backend. This will be call back from ttm_tt_destroy so
> -        * don't call ttm_tt_destroy from the callback or infinite loop.
> -        */
> -       void (*ttm_tt_destroy)(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> -
> -       /**
> -        * struct ttm_bo_driver member eviction_valuable
> -        *
> -        * @bo: the buffer object to be evicted
> -        * @place: placement we need room for
> -        *
> -        * Check with the driver if it is valuable to evict a BO to make room
> -        * for a certain placement.
> -        */
> -       bool (*eviction_valuable)(struct ttm_buffer_object *bo,
> -                                 const struct ttm_place *place);
> -       /**
> -        * struct ttm_bo_driver member evict_flags:
> -        *
> -        * @bo: the buffer object to be evicted
> -        *
> -        * Return the bo flags for a buffer which is not mapped to the hardware.
> -        * These will be placed in proposed_flags so that when the move is
> -        * finished, they'll end up in bo->mem.flags
> -        * This should not cause multihop evictions, and the core will warn
> -        * if one is proposed.
> -        */
> -
> -       void (*evict_flags)(struct ttm_buffer_object *bo,
> -                           struct ttm_placement *placement);
> -
> -       /**
> -        * struct ttm_bo_driver member move:
> -        *
> -        * @bo: the buffer to move
> -        * @evict: whether this motion is evicting the buffer from
> -        * the graphics address space
> -        * @ctx: context for this move with parameters
> -        * @new_mem: the new memory region receiving the buffer
> -        @ @hop: placement for driver directed intermediate hop
> -        *
> -        * Move a buffer between two memory regions.
> -        * Returns errno -EMULTIHOP if driver requests a hop
> -        */
> -       int (*move)(struct ttm_buffer_object *bo, bool evict,
> -                   struct ttm_operation_ctx *ctx,
> -                   struct ttm_resource *new_mem,
> -                   struct ttm_place *hop);
> -
> -       /**
> -        * struct ttm_bo_driver_member verify_access
> -        *
> -        * @bo: Pointer to a buffer object.
> -        * @filp: Pointer to a struct file trying to access the object.
> -        *
> -        * Called from the map / write / read methods to verify that the
> -        * caller is permitted to access the buffer object.
> -        * This member may be set to NULL, which will refuse this kind of
> -        * access for all buffer objects.
> -        * This function should return 0 if access is granted, -EPERM otherwise.
> -        */
> -       int (*verify_access)(struct ttm_buffer_object *bo,
> -                            struct file *filp);
> -
> -       /**
> -        * Hook to notify driver about a resource delete.
> -        */
> -       void (*delete_mem_notify)(struct ttm_buffer_object *bo);
> -
> -       /**
> -        * notify the driver that we're about to swap out this bo
> -        */
> -       void (*swap_notify)(struct ttm_buffer_object *bo);
> -
> -       /**
> -        * Driver callback on when mapping io memory (for bo_move_memcpy
> -        * for instance). TTM will take care to call io_mem_free whenever
> -        * the mapping is not use anymore. io_mem_reserve & io_mem_free
> -        * are balanced.
> -        */
> -       int (*io_mem_reserve)(struct ttm_bo_device *bdev,
> -                             struct ttm_resource *mem);
> -       void (*io_mem_free)(struct ttm_bo_device *bdev,
> -                           struct ttm_resource *mem);
> -
> -       /**
> -        * Return the pfn for a given page_offset inside the BO.
> -        *
> -        * @bo: the BO to look up the pfn for
> -        * @page_offset: the offset to look up
> -        */
> -       unsigned long (*io_mem_pfn)(struct ttm_buffer_object *bo,
> -                                   unsigned long page_offset);
> -
> -       /**
> -        * Read/write memory buffers for ptrace access
> -        *
> -        * @bo: the BO to access
> -        * @offset: the offset from the start of the BO
> -        * @buf: pointer to source/destination buffer
> -        * @len: number of bytes to copy
> -        * @write: whether to read (0) from or write (non-0) to BO
> -        *
> -        * If successful, this function should return the number of
> -        * bytes copied, -EIO otherwise. If the number of bytes
> -        * returned is < len, the function may be called again with
> -        * the remainder of the buffer to copy.
> -        */
> -       int (*access_memory)(struct ttm_buffer_object *bo, unsigned long offset,
> -                            void *buf, int len, int write);
> -
> -       /**
> -        * struct ttm_bo_driver member del_from_lru_notify
> -        *
> -        * @bo: the buffer object deleted from lru
> -        *
> -        * notify driver that a BO was deleted from LRU.
> -        */
> -       void (*del_from_lru_notify)(struct ttm_buffer_object *bo);
> -
> -       /**
> -        * Notify the driver that we're about to release a BO
> -        *
> -        * @bo: BO that is about to be released
> -        *
> -        * Gives the driver a chance to do any cleanup, including
> -        * adding fences that may force a delayed delete
> -        */
> -       void (*release_notify)(struct ttm_buffer_object *bo);
> -};
> -
> -/**
> - * struct ttm_bo_global - Buffer object driver global data.
> - *
> - * @dummy_read_page: Pointer to a dummy page used for mapping requests
> - * of unpopulated pages.
> - * @shrink: A shrink callback object used for buffer object swap.
> - * @device_list_mutex: Mutex protecting the device list.
> - * This mutex is held while traversing the device list for pm options.
> - * @lru_lock: Spinlock protecting the bo subsystem lru lists.
> - * @device_list: List of buffer object devices.
> - * @swap_lru: Lru list of buffer objects used for swapping.
> - */
> -
> -extern struct ttm_bo_global {
> -
> -       /**
> -        * Constant after init.
> -        */
> -
> -       struct kobject kobj;
> -       struct page *dummy_read_page;
> -       spinlock_t lru_lock;
> -
> -       /**
> -        * Protected by ttm_global_mutex.
> -        */
> -       struct list_head device_list;
> -
> -       /**
> -        * Protected by the lru_lock.
> -        */
> -       struct list_head swap_lru[TTM_MAX_BO_PRIORITY];
> -
> -       /**
> -        * Internal protection.
> -        */
> -       atomic_t bo_count;
> -} ttm_bo_glob;
> -
> -
> -#define TTM_NUM_MEM_TYPES 8
> -
> -/**
> - * struct ttm_bo_device - Buffer object driver device-specific data.
> - *
> - * @driver: Pointer to a struct ttm_bo_driver struct setup by the driver.
> - * @man: An array of resource_managers.
> - * @vma_manager: Address space manager (pointer)
> - * lru_lock: Spinlock that protects the buffer+device lru lists and
> - * ddestroy lists.
> - * @dev_mapping: A pointer to the struct address_space representing the
> - * device address space.
> - * @wq: Work queue structure for the delayed delete workqueue.
> - *
> - */
> -
> -struct ttm_bo_device {
> -
> -       /*
> -        * Constant after bo device init / atomic.
> -        */
> -       struct list_head device_list;
> -       struct ttm_bo_driver *driver;
> -       /*
> -        * access via ttm_manager_type.
> -        */
> -       struct ttm_resource_manager sysman;
> -       struct ttm_resource_manager *man_drv[TTM_NUM_MEM_TYPES];
> -       /*
> -        * Protected by internal locks.
> -        */
> -       struct drm_vma_offset_manager *vma_manager;
> -       struct ttm_pool pool;
> -
> -       /*
> -        * Protected by the global:lru lock.
> -        */
> -       struct list_head ddestroy;
> -
> -       /*
> -        * Protected by load / firstopen / lastclose /unload sync.
> -        */
> -
> -       struct address_space *dev_mapping;
> -
> -       /*
> -        * Internal protection.
> -        */
> -
> -       struct delayed_work wq;
> -};
> -
> -static inline struct ttm_resource_manager *ttm_manager_type(struct ttm_bo_device *bdev,
> -                                                           int mem_type)
> -{
> -       return bdev->man_drv[mem_type];
> -}
> -
> -static inline void ttm_set_driver_manager(struct ttm_bo_device *bdev,
> -                                         int type,
> -                                         struct ttm_resource_manager *manager)
> -{
> -       bdev->man_drv[type] = manager;
> -}
> -
>  /**
>   * struct ttm_lru_bulk_move_pos
>   *
> @@ -388,31 +101,6 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
>                      struct ttm_resource *mem,
>                      struct ttm_operation_ctx *ctx);
>
> -int ttm_bo_device_release(struct ttm_bo_device *bdev);
> -
> -/**
> - * ttm_bo_device_init
> - *
> - * @bdev: A pointer to a struct ttm_bo_device to initialize.
> - * @glob: A pointer to an initialized struct ttm_bo_global.
> - * @driver: A pointer to a struct ttm_bo_driver set up by the caller.
> - * @dev: The core kernel device pointer for DMA mappings and allocations.
> - * @mapping: The address space to use for this bo.
> - * @vma_manager: A pointer to a vma manager.
> - * @use_dma_alloc: If coherent DMA allocation API should be used.
> - * @use_dma32: If we should use GFP_DMA32 for device memory allocations.
> - *
> - * Initializes a struct ttm_bo_device:
> - * Returns:
> - * !0: Failure.
> - */
> -int ttm_bo_device_init(struct ttm_bo_device *bdev,
> -                      struct ttm_bo_driver *driver,
> -                      struct device *dev,
> -                      struct address_space *mapping,
> -                      struct drm_vma_offset_manager *vma_manager,
> -                      bool use_dma_alloc, bool use_dma32);
> -
>  /**
>   * ttm_bo_unmap_virtual
>   *
> @@ -494,9 +182,9 @@ static inline int ttm_bo_reserve_slowpath(struct ttm_buffer_object *bo,
>  static inline void
>  ttm_bo_move_to_lru_tail_unlocked(struct ttm_buffer_object *bo)
>  {
> -       spin_lock(&ttm_bo_glob.lru_lock);
> +       spin_lock(&ttm_glob.lru_lock);
>         ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
> -       spin_unlock(&ttm_bo_glob.lru_lock);
> +       spin_unlock(&ttm_glob.lru_lock);
>  }
>
>  static inline void ttm_bo_assign_mem(struct ttm_buffer_object *bo,
> @@ -538,9 +226,9 @@ static inline void ttm_bo_unreserve(struct ttm_buffer_object *bo)
>  /*
>   * ttm_bo_util.c
>   */
> -int ttm_mem_io_reserve(struct ttm_bo_device *bdev,
> +int ttm_mem_io_reserve(struct ttm_device *bdev,
>                        struct ttm_resource *mem);
> -void ttm_mem_io_free(struct ttm_bo_device *bdev,
> +void ttm_mem_io_free(struct ttm_device *bdev,
>                      struct ttm_resource *mem);
>
>  /**
> @@ -631,7 +319,7 @@ void ttm_bo_tt_destroy(struct ttm_buffer_object *bo);
>   * Initialise a generic range manager for the selected memory type.
>   * The range manager is installed for this device in the type slot.
>   */
> -int ttm_range_man_init(struct ttm_bo_device *bdev,
> +int ttm_range_man_init(struct ttm_device *bdev,
>                        unsigned type, bool use_tt,
>                        unsigned long p_size);
>
> @@ -643,7 +331,7 @@ int ttm_range_man_init(struct ttm_bo_device *bdev,
>   *
>   * Remove the generic range manager from a slot and tear it down.
>   */
> -int ttm_range_man_fini(struct ttm_bo_device *bdev,
> +int ttm_range_man_fini(struct ttm_device *bdev,
>                        unsigned type);
>
>  #endif
> diff --git a/include/drm/ttm/ttm_device.h b/include/drm/ttm/ttm_device.h
> new file mode 100644
> index 000000000000..7bc8bb797161
> --- /dev/null
> +++ b/include/drm/ttm/ttm_device.h
> @@ -0,0 +1,319 @@
> +/*
> + * Copyright 2020 Advanced Micro Devices, Inc.
> + *
> + * Permission is hereby granted, free of charge, to any person obtaining a
> + * copy of this software and associated documentation files (the "Software"),
> + * to deal in the Software without restriction, including without limitation
> + * the rights to use, copy, modify, merge, publish, distribute, sublicense,
> + * and/or sell copies of the Software, and to permit persons to whom the
> + * Software is furnished to do so, subject to the following conditions:
> + *
> + * The above copyright notice and this permission notice shall be included in
> + * all copies or substantial portions of the Software.
> + *
> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
> + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
> + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
> + * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
> + * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
> + * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
> + * OTHER DEALINGS IN THE SOFTWARE.
> + *
> + * Authors: Christian König
> + */
> +
> +#ifndef _TTM_DEVICE_H_
> +#define _TTM_DEVICE_H_
> +
> +#include <linux/types.h>
> +#include <linux/workqueue.h>
> +#include <drm/ttm/ttm_resource.h>
> +#include <drm/ttm/ttm_pool.h>
> +
> +#define TTM_NUM_MEM_TYPES 8
> +
> +struct ttm_device;
> +struct ttm_placement;
> +struct ttm_buffer_object;
> +struct ttm_operation_ctx;
> +
> +/**
> + * struct ttm_global - Buffer object driver global data.
> + *
> + * @dummy_read_page: Pointer to a dummy page used for mapping requests
> + * of unpopulated pages.
> + * @shrink: A shrink callback object used for buffer object swap.
> + * @device_list_mutex: Mutex protecting the device list.
> + * This mutex is held while traversing the device list for pm options.
> + * @lru_lock: Spinlock protecting the bo subsystem lru lists.
> + * @device_list: List of buffer object devices.
> + * @swap_lru: Lru list of buffer objects used for swapping.
> + */
> +extern struct ttm_global {
> +
> +       /**
> +        * Constant after init.
> +        */
> +
> +       struct kobject kobj;
> +       struct page *dummy_read_page;
> +       spinlock_t lru_lock;
> +
> +       /**
> +        * Protected by ttm_global_mutex.
> +        */
> +       struct list_head device_list;
> +
> +       /**
> +        * Protected by the lru_lock.
> +        */
> +       struct list_head swap_lru[TTM_MAX_BO_PRIORITY];
> +
> +       /**
> +        * Internal protection.
> +        */
> +       atomic_t bo_count;
> +} ttm_glob;
> +
> +struct ttm_device_funcs {
> +       /**
> +        * ttm_tt_create
> +        *
> +        * @bo: The buffer object to create the ttm for.
> +        * @page_flags: Page flags as identified by TTM_PAGE_FLAG_XX flags.
> +        *
> +        * Create a struct ttm_tt to back data with system memory pages.
> +        * No pages are actually allocated.
> +        * Returns:
> +        * NULL: Out of memory.
> +        */
> +       struct ttm_tt *(*ttm_tt_create)(struct ttm_buffer_object *bo,
> +                                       uint32_t page_flags);
> +
> +       /**
> +        * ttm_tt_populate
> +        *
> +        * @ttm: The struct ttm_tt to contain the backing pages.
> +        *
> +        * Allocate all backing pages
> +        * Returns:
> +        * -ENOMEM: Out of memory.
> +        */
> +       int (*ttm_tt_populate)(struct ttm_device *bdev,
> +                              struct ttm_tt *ttm,
> +                              struct ttm_operation_ctx *ctx);
> +
> +       /**
> +        * ttm_tt_unpopulate
> +        *
> +        * @ttm: The struct ttm_tt to contain the backing pages.
> +        *
> +        * Free all backing page
> +        */
> +       void (*ttm_tt_unpopulate)(struct ttm_device *bdev,
> +                                 struct ttm_tt *ttm);
> +
> +       /**
> +        * ttm_tt_destroy
> +        *
> +        * @bdev: Pointer to a ttm device
> +        * @ttm: Pointer to a struct ttm_tt.
> +        *
> +        * Destroy the backend. This will be call back from ttm_tt_destroy so
> +        * don't call ttm_tt_destroy from the callback or infinite loop.
> +        */
> +       void (*ttm_tt_destroy)(struct ttm_device *bdev, struct ttm_tt *ttm);
> +
> +       /**
> +        * struct ttm_bo_driver member eviction_valuable
> +        *
> +        * @bo: the buffer object to be evicted
> +        * @place: placement we need room for
> +        *
> +        * Check with the driver if it is valuable to evict a BO to make room
> +        * for a certain placement.
> +        */
> +       bool (*eviction_valuable)(struct ttm_buffer_object *bo,
> +                                 const struct ttm_place *place);
> +       /**
> +        * struct ttm_bo_driver member evict_flags:
> +        *
> +        * @bo: the buffer object to be evicted
> +        *
> +        * Return the bo flags for a buffer which is not mapped to the hardware.
> +        * These will be placed in proposed_flags so that when the move is
> +        * finished, they'll end up in bo->mem.flags
> +        * This should not cause multihop evictions, and the core will warn
> +        * if one is proposed.
> +        */
> +
> +       void (*evict_flags)(struct ttm_buffer_object *bo,
> +                           struct ttm_placement *placement);
> +
> +       /**
> +        * struct ttm_bo_driver member move:
> +        *
> +        * @bo: the buffer to move
> +        * @evict: whether this motion is evicting the buffer from
> +        * the graphics address space
> +        * @ctx: context for this move with parameters
> +        * @new_mem: the new memory region receiving the buffer
> +        @ @hop: placement for driver directed intermediate hop
> +        *
> +        * Move a buffer between two memory regions.
> +        * Returns errno -EMULTIHOP if driver requests a hop
> +        */
> +       int (*move)(struct ttm_buffer_object *bo, bool evict,
> +                   struct ttm_operation_ctx *ctx,
> +                   struct ttm_resource *new_mem,
> +                   struct ttm_place *hop);
> +
> +       /**
> +        * struct ttm_bo_driver_member verify_access
> +        *
> +        * @bo: Pointer to a buffer object.
> +        * @filp: Pointer to a struct file trying to access the object.
> +        *
> +        * Called from the map / write / read methods to verify that the
> +        * caller is permitted to access the buffer object.
> +        * This member may be set to NULL, which will refuse this kind of
> +        * access for all buffer objects.
> +        * This function should return 0 if access is granted, -EPERM otherwise.
> +        */
> +       int (*verify_access)(struct ttm_buffer_object *bo,
> +                            struct file *filp);
> +
> +       /**
> +        * Hook to notify driver about a resource delete.
> +        */
> +       void (*delete_mem_notify)(struct ttm_buffer_object *bo);
> +
> +       /**
> +        * notify the driver that we're about to swap out this bo
> +        */
> +       void (*swap_notify)(struct ttm_buffer_object *bo);
> +
> +       /**
> +        * Driver callback on when mapping io memory (for bo_move_memcpy
> +        * for instance). TTM will take care to call io_mem_free whenever
> +        * the mapping is not use anymore. io_mem_reserve & io_mem_free
> +        * are balanced.
> +        */
> +       int (*io_mem_reserve)(struct ttm_device *bdev,
> +                             struct ttm_resource *mem);
> +       void (*io_mem_free)(struct ttm_device *bdev,
> +                           struct ttm_resource *mem);
> +
> +       /**
> +        * Return the pfn for a given page_offset inside the BO.
> +        *
> +        * @bo: the BO to look up the pfn for
> +        * @page_offset: the offset to look up
> +        */
> +       unsigned long (*io_mem_pfn)(struct ttm_buffer_object *bo,
> +                                   unsigned long page_offset);
> +
> +       /**
> +        * Read/write memory buffers for ptrace access
> +        *
> +        * @bo: the BO to access
> +        * @offset: the offset from the start of the BO
> +        * @buf: pointer to source/destination buffer
> +        * @len: number of bytes to copy
> +        * @write: whether to read (0) from or write (non-0) to BO
> +        *
> +        * If successful, this function should return the number of
> +        * bytes copied, -EIO otherwise. If the number of bytes
> +        * returned is < len, the function may be called again with
> +        * the remainder of the buffer to copy.
> +        */
> +       int (*access_memory)(struct ttm_buffer_object *bo, unsigned long offset,
> +                            void *buf, int len, int write);
> +
> +       /**
> +        * struct ttm_bo_driver member del_from_lru_notify
> +        *
> +        * @bo: the buffer object deleted from lru
> +        *
> +        * notify driver that a BO was deleted from LRU.
> +        */
> +       void (*del_from_lru_notify)(struct ttm_buffer_object *bo);
> +
> +       /**
> +        * Notify the driver that we're about to release a BO
> +        *
> +        * @bo: BO that is about to be released
> +        *
> +        * Gives the driver a chance to do any cleanup, including
> +        * adding fences that may force a delayed delete
> +        */
> +       void (*release_notify)(struct ttm_buffer_object *bo);
> +};
> +
> +/**
> + * struct ttm_device - Buffer object driver device-specific data.
> + *
> + * @device_list: Our entry in the global device list.
> + * @funcs: Function table for the device.
> + * @sysman: Resource manager for the system domain.
> + * @man_drv: An array of resource_managers.
> + * @vma_manager: Address space manager.
> + * @pool: page pool for the device.
> + * @dev_mapping: A pointer to the struct address_space representing the
> + * device address space.
> + * @wq: Work queue structure for the delayed delete workqueue.
> + */
> +struct ttm_device {
> +       /*
> +        * Constant after bo device init
> +        */
> +       struct list_head device_list;
> +       struct ttm_device_funcs *funcs;
> +
> +       /*
> +        * Access via ttm_manager_type.
> +        */
> +       struct ttm_resource_manager sysman;
> +       struct ttm_resource_manager *man_drv[TTM_NUM_MEM_TYPES];
> +
> +       /*
> +        * Protected by internal locks.
> +        */
> +       struct drm_vma_offset_manager *vma_manager;
> +       struct ttm_pool pool;
> +
> +       /*
> +        * Protected by the global:lru lock.
> +        */
> +       struct list_head ddestroy;
> +
> +       /*
> +        * Protected by load / firstopen / lastclose /unload sync.
> +        */
> +       struct address_space *dev_mapping;
> +
> +       /*
> +        * Internal protection.
> +        */
> +       struct delayed_work wq;
> +};
> +
> +static inline struct ttm_resource_manager *
> +ttm_manager_type(struct ttm_device *bdev, int mem_type)
> +{
> +       return bdev->man_drv[mem_type];
> +}
> +
> +static inline void ttm_set_driver_manager(struct ttm_device *bdev, int type,
> +                                         struct ttm_resource_manager *manager)
> +{
> +       bdev->man_drv[type] = manager;
> +}
> +
> +int ttm_device_init(struct ttm_device *bdev, struct ttm_device_funcs *funcs,
> +                   struct device *dev, struct address_space *mapping,
> +                   struct drm_vma_offset_manager *vma_manager,
> +                   bool use_dma_alloc, bool use_dma32);
> +void ttm_device_fini(struct ttm_device *bdev);
> +
> +#endif
> diff --git a/include/drm/ttm/ttm_resource.h b/include/drm/ttm/ttm_resource.h
> index da0ed7e8c915..6164ccf4f308 100644
> --- a/include/drm/ttm/ttm_resource.h
> +++ b/include/drm/ttm/ttm_resource.h
> @@ -33,7 +33,7 @@
>
>  #define TTM_MAX_BO_PRIORITY    4U
>
> -struct ttm_bo_device;
> +struct ttm_device;
>  struct ttm_resource_manager;
>  struct ttm_resource;
>  struct ttm_place;
> @@ -233,7 +233,7 @@ void ttm_resource_free(struct ttm_buffer_object *bo, struct ttm_resource *res);
>  void ttm_resource_manager_init(struct ttm_resource_manager *man,
>                                unsigned long p_size);
>
> -int ttm_resource_manager_evict_all(struct ttm_bo_device *bdev,
> +int ttm_resource_manager_evict_all(struct ttm_device *bdev,
>                                    struct ttm_resource_manager *man);
>
>  void ttm_resource_manager_debug(struct ttm_resource_manager *man,
> diff --git a/include/drm/ttm/ttm_tt.h b/include/drm/ttm/ttm_tt.h
> index 6c8eb9a4de81..0020a0588985 100644
> --- a/include/drm/ttm/ttm_tt.h
> +++ b/include/drm/ttm/ttm_tt.h
> @@ -118,14 +118,14 @@ void ttm_tt_fini(struct ttm_tt *ttm);
>   *
>   * Unbind, unpopulate and destroy common struct ttm_tt.
>   */
> -void ttm_tt_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +void ttm_tt_destroy(struct ttm_device *bdev, struct ttm_tt *ttm);
>
>  /**
>   * ttm_tt_destroy_common:
>   *
>   * Called from driver to destroy common path.
>   */
> -void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +void ttm_tt_destroy_common(struct ttm_device *bdev, struct ttm_tt *ttm);
>
>  /**
>   * ttm_tt_swapin:
> @@ -135,7 +135,7 @@ void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>   * Swap in a previously swap out ttm_tt.
>   */
>  int ttm_tt_swapin(struct ttm_tt *ttm);
> -int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +int ttm_tt_swapout(struct ttm_device *bdev, struct ttm_tt *ttm);
>
>  /**
>   * ttm_tt_populate - allocate pages for a ttm
> @@ -144,7 +144,7 @@ int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>   *
>   * Calls the driver method to allocate pages for a ttm
>   */
> -int ttm_tt_populate(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_operation_ctx *ctx);
> +int ttm_tt_populate(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_operation_ctx *ctx);
>
>  /**
>   * ttm_tt_unpopulate - free pages from a ttm
> @@ -153,7 +153,7 @@ int ttm_tt_populate(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_o
>   *
>   * Calls the driver method to free all pages from a ttm
>   */
> -void ttm_tt_unpopulate(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +void ttm_tt_unpopulate(struct ttm_device *bdev, struct ttm_tt *ttm);
>
>  #if IS_ENABLED(CONFIG_AGP)
>  #include <linux/agp_backend.h>
> --
> 2.25.1
>


-- 
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch
_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH] drm/ttm: device naming cleanup
  2021-01-21 13:39 ` Daniel Vetter
@ 2021-01-21 13:45   ` Christian König
  0 siblings, 0 replies; 4+ messages in thread
From: Christian König @ 2021-01-21 13:45 UTC (permalink / raw)
  To: Daniel Vetter; +Cc: Huang Rui, dri-devel

Am 21.01.21 um 14:39 schrieb Daniel Vetter:
> On Thu, Jan 21, 2021 at 12:58 PM Christian König
> <ckoenig.leichtzumerken@gmail.com> wrote:
>> Rename ttm_bo_device to ttm_device.
>> Rename ttm_bo_driver to ttm_device_funcs.
>> Rename ttm_bo_global to ttm_global.
>>
>> Move global and device related functions to ttm_device.[ch].
>>
>> No functional change.
>>
>> Signed-off-by: Christian König <christian.koenig@amd.com>
> I didn't check it all, but makes a lot of sense to do this.

Yeah, mostly automated generated.

> Acked-by: Daniel Vetter <daniel.vetter@ffwll.ch>

Going to push that now before I get even more conflicts :)

Thanks,
Christian.

>
>> ---
>>   drivers/gpu/drm/amd/amdgpu/amdgpu.h           |   2 +-
>>   .../gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c  |   6 +-
>>   drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c      |   2 +-
>>   drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c       |  26 +-
>>   drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h       |   2 +-
>>   drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c        |   8 +-
>>   drivers/gpu/drm/drm_gem_vram_helper.c         |  14 +-
>>   drivers/gpu/drm/nouveau/nouveau_bo.c          |  20 +-
>>   drivers/gpu/drm/nouveau/nouveau_bo.h          |   2 +-
>>   drivers/gpu/drm/nouveau/nouveau_drv.h         |   2 +-
>>   drivers/gpu/drm/nouveau/nouveau_sgdma.c       |   6 +-
>>   drivers/gpu/drm/nouveau/nouveau_ttm.c         |  10 +-
>>   drivers/gpu/drm/nouveau/nouveau_ttm.h         |   8 +-
>>   drivers/gpu/drm/qxl/qxl_drv.h                 |   4 +-
>>   drivers/gpu/drm/qxl/qxl_release.c             |   6 +-
>>   drivers/gpu/drm/qxl/qxl_ttm.c                 |  19 +-
>>   drivers/gpu/drm/radeon/radeon.h               |   6 +-
>>   drivers/gpu/drm/radeon/radeon_object.c        |   2 +-
>>   drivers/gpu/drm/radeon/radeon_ttm.c           |  38 +-
>>   drivers/gpu/drm/ttm/Makefile                  |   2 +-
>>   drivers/gpu/drm/ttm/ttm_agp_backend.c         |   2 +-
>>   drivers/gpu/drm/ttm/ttm_bo.c                  | 256 +++-----------
>>   drivers/gpu/drm/ttm/ttm_bo_util.c             |  24 +-
>>   drivers/gpu/drm/ttm/ttm_bo_vm.c               |  24 +-
>>   drivers/gpu/drm/ttm/ttm_device.c              | 195 +++++++++++
>>   drivers/gpu/drm/ttm/ttm_execbuf_util.c        |   8 +-
>>   drivers/gpu/drm/ttm/ttm_range_manager.c       |   4 +-
>>   drivers/gpu/drm/ttm/ttm_resource.c            |   4 +-
>>   drivers/gpu/drm/ttm/ttm_tt.c                  |  26 +-
>>   drivers/gpu/drm/vmwgfx/vmwgfx_blit.c          |   4 +-
>>   drivers/gpu/drm/vmwgfx/vmwgfx_bo.c            |   4 +-
>>   drivers/gpu/drm/vmwgfx/vmwgfx_drv.c           |  16 +-
>>   drivers/gpu/drm/vmwgfx/vmwgfx_drv.h           |   4 +-
>>   drivers/gpu/drm/vmwgfx/vmwgfx_resource.c      |   2 +-
>>   drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c    |  14 +-
>>   include/drm/drm_gem_vram_helper.h             |   6 +-
>>   include/drm/ttm/ttm_bo_api.h                  |  35 +-
>>   include/drm/ttm/ttm_bo_driver.h               | 328 +-----------------
>>   include/drm/ttm/ttm_device.h                  | 319 +++++++++++++++++
>>   include/drm/ttm/ttm_resource.h                |   4 +-
>>   include/drm/ttm/ttm_tt.h                      |  10 +-
>>   41 files changed, 759 insertions(+), 715 deletions(-)
>>   create mode 100644 drivers/gpu/drm/ttm/ttm_device.c
>>   create mode 100644 include/drm/ttm/ttm_device.h
>>
>> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu.h b/drivers/gpu/drm/amd/amdgpu/amdgpu.h
>> index f77443cd9c17..ab4ac3b2651e 100644
>> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu.h
>> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu.h
>> @@ -1053,7 +1053,7 @@ static inline struct drm_device *adev_to_drm(struct amdgpu_device *adev)
>>          return &adev->ddev;
>>   }
>>
>> -static inline struct amdgpu_device *amdgpu_ttm_adev(struct ttm_bo_device *bdev)
>> +static inline struct amdgpu_device *amdgpu_ttm_adev(struct ttm_device *bdev)
>>   {
>>          return container_of(bdev, struct amdgpu_device, mman.bdev);
>>   }
>> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c
>> index 3107b9575929..5af464933976 100644
>> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c
>> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c
>> @@ -40,13 +40,13 @@ static atomic_t fence_seq = ATOMIC_INIT(0);
>>    * All the BOs in a process share an eviction fence. When process X wants
>>    * to map VRAM memory but TTM can't find enough space, TTM will attempt to
>>    * evict BOs from its LRU list. TTM checks if the BO is valuable to evict
>> - * by calling ttm_bo_driver->eviction_valuable().
>> + * by calling ttm_device_funcs->eviction_valuable().
>>    *
>> - * ttm_bo_driver->eviction_valuable() - will return false if the BO belongs
>> + * ttm_device_funcs->eviction_valuable() - will return false if the BO belongs
>>    *  to process X. Otherwise, it will return true to indicate BO can be
>>    *  evicted by TTM.
>>    *
>> - * If ttm_bo_driver->eviction_valuable returns true, then TTM will continue
>> + * If ttm_device_funcs->eviction_valuable returns true, then TTM will continue
>>    * the evcition process for that BO by calling ttm_bo_evict --> amdgpu_bo_move
>>    * --> amdgpu_copy_buffer(). This sets up job in GPU scheduler.
>>    *
>> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c
>> index 0db933026722..fde2d899b2c4 100644
>> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c
>> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c
>> @@ -71,7 +71,7 @@
>>    */
>>   static int amdgpu_gart_dummy_page_init(struct amdgpu_device *adev)
>>   {
>> -       struct page *dummy_page = ttm_bo_glob.dummy_read_page;
>> +       struct page *dummy_page = ttm_glob.dummy_read_page;
>>
>>          if (adev->dummy_page_addr)
>>                  return 0;
>> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
>> index 9fd2157b133a..29cfb0809634 100644
>> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
>> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
>> @@ -61,10 +61,10 @@
>>
>>   #define AMDGPU_TTM_VRAM_MAX_DW_READ    (size_t)128
>>
>> -static int amdgpu_ttm_backend_bind(struct ttm_bo_device *bdev,
>> +static int amdgpu_ttm_backend_bind(struct ttm_device *bdev,
>>                                     struct ttm_tt *ttm,
>>                                     struct ttm_resource *bo_mem);
>> -static void amdgpu_ttm_backend_unbind(struct ttm_bo_device *bdev,
>> +static void amdgpu_ttm_backend_unbind(struct ttm_device *bdev,
>>                                        struct ttm_tt *ttm);
>>
>>   static int amdgpu_ttm_init_on_chip(struct amdgpu_device *adev,
>> @@ -646,7 +646,7 @@ static int amdgpu_bo_move(struct ttm_buffer_object *bo, bool evict,
>>    *
>>    * Called by ttm_mem_io_reserve() ultimately via ttm_bo_vm_fault()
>>    */
>> -static int amdgpu_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *mem)
>> +static int amdgpu_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *mem)
>>   {
>>          struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
>>          struct drm_mm_node *mm_node = mem->mm_node;
>> @@ -893,7 +893,7 @@ void amdgpu_ttm_tt_set_user_pages(struct ttm_tt *ttm, struct page **pages)
>>    *
>>    * Called by amdgpu_ttm_backend_bind()
>>    **/
>> -static int amdgpu_ttm_tt_pin_userptr(struct ttm_bo_device *bdev,
>> +static int amdgpu_ttm_tt_pin_userptr(struct ttm_device *bdev,
>>                                       struct ttm_tt *ttm)
>>   {
>>          struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
>> @@ -931,7 +931,7 @@ static int amdgpu_ttm_tt_pin_userptr(struct ttm_bo_device *bdev,
>>   /*
>>    * amdgpu_ttm_tt_unpin_userptr - Unpin and unmap userptr pages
>>    */
>> -static void amdgpu_ttm_tt_unpin_userptr(struct ttm_bo_device *bdev,
>> +static void amdgpu_ttm_tt_unpin_userptr(struct ttm_device *bdev,
>>                                          struct ttm_tt *ttm)
>>   {
>>          struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
>> @@ -1015,7 +1015,7 @@ static int amdgpu_ttm_gart_bind(struct amdgpu_device *adev,
>>    * Called by ttm_tt_bind() on behalf of ttm_bo_handle_move_mem().
>>    * This handles binding GTT memory to the device address space.
>>    */
>> -static int amdgpu_ttm_backend_bind(struct ttm_bo_device *bdev,
>> +static int amdgpu_ttm_backend_bind(struct ttm_device *bdev,
>>                                     struct ttm_tt *ttm,
>>                                     struct ttm_resource *bo_mem)
>>   {
>> @@ -1155,7 +1155,7 @@ int amdgpu_ttm_recover_gart(struct ttm_buffer_object *tbo)
>>    * Called by ttm_tt_unbind() on behalf of ttm_bo_move_ttm() and
>>    * ttm_tt_destroy().
>>    */
>> -static void amdgpu_ttm_backend_unbind(struct ttm_bo_device *bdev,
>> +static void amdgpu_ttm_backend_unbind(struct ttm_device *bdev,
>>                                        struct ttm_tt *ttm)
>>   {
>>          struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
>> @@ -1180,7 +1180,7 @@ static void amdgpu_ttm_backend_unbind(struct ttm_bo_device *bdev,
>>          gtt->bound = false;
>>   }
>>
>> -static void amdgpu_ttm_backend_destroy(struct ttm_bo_device *bdev,
>> +static void amdgpu_ttm_backend_destroy(struct ttm_device *bdev,
>>                                         struct ttm_tt *ttm)
>>   {
>>          struct amdgpu_ttm_tt *gtt = (void *)ttm;
>> @@ -1234,7 +1234,7 @@ static struct ttm_tt *amdgpu_ttm_tt_create(struct ttm_buffer_object *bo,
>>    * Map the pages of a ttm_tt object to an address space visible
>>    * to the underlying device.
>>    */
>> -static int amdgpu_ttm_tt_populate(struct ttm_bo_device *bdev,
>> +static int amdgpu_ttm_tt_populate(struct ttm_device *bdev,
>>                                    struct ttm_tt *ttm,
>>                                    struct ttm_operation_ctx *ctx)
>>   {
>> @@ -1278,7 +1278,7 @@ static int amdgpu_ttm_tt_populate(struct ttm_bo_device *bdev,
>>    * Unmaps pages of a ttm_tt object from the device address space and
>>    * unpopulates the page array backing it.
>>    */
>> -static void amdgpu_ttm_tt_unpopulate(struct ttm_bo_device *bdev,
>> +static void amdgpu_ttm_tt_unpopulate(struct ttm_device *bdev,
>>                                       struct ttm_tt *ttm)
>>   {
>>          struct amdgpu_ttm_tt *gtt = (void *)ttm;
>> @@ -1603,7 +1603,7 @@ amdgpu_bo_delete_mem_notify(struct ttm_buffer_object *bo)
>>          amdgpu_bo_move_notify(bo, false, NULL);
>>   }
>>
>> -static struct ttm_bo_driver amdgpu_bo_driver = {
>> +static struct ttm_device_funcs amdgpu_bo_driver = {
>>          .ttm_tt_create = &amdgpu_ttm_tt_create,
>>          .ttm_tt_populate = &amdgpu_ttm_tt_populate,
>>          .ttm_tt_unpopulate = &amdgpu_ttm_tt_unpopulate,
>> @@ -1785,7 +1785,7 @@ int amdgpu_ttm_init(struct amdgpu_device *adev)
>>          mutex_init(&adev->mman.gtt_window_lock);
>>
>>          /* No others user of address space so set it to 0 */
>> -       r = ttm_bo_device_init(&adev->mman.bdev, &amdgpu_bo_driver, adev->dev,
>> +       r = ttm_device_init(&adev->mman.bdev, &amdgpu_bo_driver, adev->dev,
>>                                 adev_to_drm(adev)->anon_inode->i_mapping,
>>                                 adev_to_drm(adev)->vma_offset_manager,
>>                                 adev->need_swiotlb,
>> @@ -1926,7 +1926,7 @@ void amdgpu_ttm_fini(struct amdgpu_device *adev)
>>          ttm_range_man_fini(&adev->mman.bdev, AMDGPU_PL_GDS);
>>          ttm_range_man_fini(&adev->mman.bdev, AMDGPU_PL_GWS);
>>          ttm_range_man_fini(&adev->mman.bdev, AMDGPU_PL_OA);
>> -       ttm_bo_device_release(&adev->mman.bdev);
>> +       ttm_device_fini(&adev->mman.bdev);
>>          adev->mman.initialized = false;
>>          DRM_INFO("amdgpu: ttm finalized\n");
>>   }
>> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h
>> index d2987536d7cd..7189f8370108 100644
>> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h
>> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h
>> @@ -60,7 +60,7 @@ struct amdgpu_gtt_mgr {
>>   };
>>
>>   struct amdgpu_mman {
>> -       struct ttm_bo_device            bdev;
>> +       struct ttm_device               bdev;
>>          bool                            initialized;
>>          void __iomem                    *aper_base_kaddr;
>>
>> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
>> index ad91c0c3c423..9d19078246c8 100644
>> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
>> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
>> @@ -638,15 +638,15 @@ void amdgpu_vm_move_to_lru_tail(struct amdgpu_device *adev,
>>          struct amdgpu_vm_bo_base *bo_base;
>>
>>          if (vm->bulk_moveable) {
>> -               spin_lock(&ttm_bo_glob.lru_lock);
>> +               spin_lock(&ttm_glob.lru_lock);
>>                  ttm_bo_bulk_move_lru_tail(&vm->lru_bulk_move);
>> -               spin_unlock(&ttm_bo_glob.lru_lock);
>> +               spin_unlock(&ttm_glob.lru_lock);
>>                  return;
>>          }
>>
>>          memset(&vm->lru_bulk_move, 0, sizeof(vm->lru_bulk_move));
>>
>> -       spin_lock(&ttm_bo_glob.lru_lock);
>> +       spin_lock(&ttm_glob.lru_lock);
>>          list_for_each_entry(bo_base, &vm->idle, vm_status) {
>>                  struct amdgpu_bo *bo = bo_base->bo;
>>
>> @@ -660,7 +660,7 @@ void amdgpu_vm_move_to_lru_tail(struct amdgpu_device *adev,
>>                                                  &bo->shadow->tbo.mem,
>>                                                  &vm->lru_bulk_move);
>>          }
>> -       spin_unlock(&ttm_bo_glob.lru_lock);
>> +       spin_unlock(&ttm_glob.lru_lock);
>>
>>          vm->bulk_moveable = true;
>>   }
>> diff --git a/drivers/gpu/drm/drm_gem_vram_helper.c b/drivers/gpu/drm/drm_gem_vram_helper.c
>> index 02ca22e90290..0b13c8507688 100644
>> --- a/drivers/gpu/drm/drm_gem_vram_helper.c
>> +++ b/drivers/gpu/drm/drm_gem_vram_helper.c
>> @@ -187,7 +187,7 @@ struct drm_gem_vram_object *drm_gem_vram_create(struct drm_device *dev,
>>          struct drm_gem_vram_object *gbo;
>>          struct drm_gem_object *gem;
>>          struct drm_vram_mm *vmm = dev->vram_mm;
>> -       struct ttm_bo_device *bdev;
>> +       struct ttm_device *bdev;
>>          int ret;
>>          size_t acc_size;
>>
>> @@ -551,7 +551,7 @@ int drm_gem_vram_fill_create_dumb(struct drm_file *file,
>>   EXPORT_SYMBOL(drm_gem_vram_fill_create_dumb);
>>
>>   /*
>> - * Helpers for struct ttm_bo_driver
>> + * Helpers for struct ttm_device_funcs
>>    */
>>
>>   static bool drm_is_gem_vram(struct ttm_buffer_object *bo)
>> @@ -893,7 +893,7 @@ static const struct drm_gem_object_funcs drm_gem_vram_object_funcs = {
>>    * TTM TT
>>    */
>>
>> -static void bo_driver_ttm_tt_destroy(struct ttm_bo_device *bdev, struct ttm_tt *tt)
>> +static void bo_driver_ttm_tt_destroy(struct ttm_device *bdev, struct ttm_tt *tt)
>>   {
>>          ttm_tt_destroy_common(bdev, tt);
>>          ttm_tt_fini(tt);
>> @@ -965,7 +965,7 @@ static int bo_driver_move(struct ttm_buffer_object *bo,
>>          return drm_gem_vram_bo_driver_move(gbo, evict, ctx, new_mem);
>>   }
>>
>> -static int bo_driver_io_mem_reserve(struct ttm_bo_device *bdev,
>> +static int bo_driver_io_mem_reserve(struct ttm_device *bdev,
>>                                      struct ttm_resource *mem)
>>   {
>>          struct drm_vram_mm *vmm = drm_vram_mm_of_bdev(bdev);
>> @@ -985,7 +985,7 @@ static int bo_driver_io_mem_reserve(struct ttm_bo_device *bdev,
>>          return 0;
>>   }
>>
>> -static struct ttm_bo_driver bo_driver = {
>> +static struct ttm_device_funcs bo_driver = {
>>          .ttm_tt_create = bo_driver_ttm_tt_create,
>>          .ttm_tt_destroy = bo_driver_ttm_tt_destroy,
>>          .eviction_valuable = ttm_bo_eviction_valuable,
>> @@ -1036,7 +1036,7 @@ static int drm_vram_mm_init(struct drm_vram_mm *vmm, struct drm_device *dev,
>>          vmm->vram_base = vram_base;
>>          vmm->vram_size = vram_size;
>>
>> -       ret = ttm_bo_device_init(&vmm->bdev, &bo_driver, dev->dev,
>> +       ret = ttm_device_init(&vmm->bdev, &bo_driver, dev->dev,
>>                                   dev->anon_inode->i_mapping,
>>                                   dev->vma_offset_manager,
>>                                   false, true);
>> @@ -1054,7 +1054,7 @@ static int drm_vram_mm_init(struct drm_vram_mm *vmm, struct drm_device *dev,
>>   static void drm_vram_mm_cleanup(struct drm_vram_mm *vmm)
>>   {
>>          ttm_range_man_fini(&vmm->bdev, TTM_PL_VRAM);
>> -       ttm_bo_device_release(&vmm->bdev);
>> +       ttm_device_fini(&vmm->bdev);
>>   }
>>
>>   /*
>> diff --git a/drivers/gpu/drm/nouveau/nouveau_bo.c b/drivers/gpu/drm/nouveau/nouveau_bo.c
>> index 33dc886d1d6d..c177940d6e2c 100644
>> --- a/drivers/gpu/drm/nouveau/nouveau_bo.c
>> +++ b/drivers/gpu/drm/nouveau/nouveau_bo.c
>> @@ -43,9 +43,9 @@
>>   #include <nvif/if500b.h>
>>   #include <nvif/if900b.h>
>>
>> -static int nouveau_ttm_tt_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm,
>> +static int nouveau_ttm_tt_bind(struct ttm_device *bdev, struct ttm_tt *ttm,
>>                                 struct ttm_resource *reg);
>> -static void nouveau_ttm_tt_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>> +static void nouveau_ttm_tt_unbind(struct ttm_device *bdev, struct ttm_tt *ttm);
>>
>>   /*
>>    * NV10-NV40 tiling helpers
>> @@ -674,7 +674,7 @@ nouveau_ttm_tt_create(struct ttm_buffer_object *bo, uint32_t page_flags)
>>   }
>>
>>   static int
>> -nouveau_ttm_tt_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm,
>> +nouveau_ttm_tt_bind(struct ttm_device *bdev, struct ttm_tt *ttm,
>>                      struct ttm_resource *reg)
>>   {
>>   #if IS_ENABLED(CONFIG_AGP)
>> @@ -690,7 +690,7 @@ nouveau_ttm_tt_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm,
>>   }
>>
>>   static void
>> -nouveau_ttm_tt_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>> +nouveau_ttm_tt_unbind(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>>   #if IS_ENABLED(CONFIG_AGP)
>>          struct nouveau_drm *drm = nouveau_bdev(bdev);
>> @@ -1055,7 +1055,7 @@ nouveau_ttm_io_mem_free_locked(struct nouveau_drm *drm,
>>   }
>>
>>   static int
>> -nouveau_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *reg)
>> +nouveau_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *reg)
>>   {
>>          struct nouveau_drm *drm = nouveau_bdev(bdev);
>>          struct nvkm_device *device = nvxx_device(&drm->client.device);
>> @@ -1163,7 +1163,7 @@ nouveau_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *reg)
>>   }
>>
>>   static void
>> -nouveau_ttm_io_mem_free(struct ttm_bo_device *bdev, struct ttm_resource *reg)
>> +nouveau_ttm_io_mem_free(struct ttm_device *bdev, struct ttm_resource *reg)
>>   {
>>          struct nouveau_drm *drm = nouveau_bdev(bdev);
>>
>> @@ -1223,7 +1223,7 @@ vm_fault_t nouveau_ttm_fault_reserve_notify(struct ttm_buffer_object *bo)
>>   }
>>
>>   static int
>> -nouveau_ttm_tt_populate(struct ttm_bo_device *bdev,
>> +nouveau_ttm_tt_populate(struct ttm_device *bdev,
>>                          struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)
>>   {
>>          struct ttm_tt *ttm_dma = (void *)ttm;
>> @@ -1247,7 +1247,7 @@ nouveau_ttm_tt_populate(struct ttm_bo_device *bdev,
>>   }
>>
>>   static void
>> -nouveau_ttm_tt_unpopulate(struct ttm_bo_device *bdev,
>> +nouveau_ttm_tt_unpopulate(struct ttm_device *bdev,
>>                            struct ttm_tt *ttm)
>>   {
>>          struct nouveau_drm *drm;
>> @@ -1264,7 +1264,7 @@ nouveau_ttm_tt_unpopulate(struct ttm_bo_device *bdev,
>>   }
>>
>>   static void
>> -nouveau_ttm_tt_destroy(struct ttm_bo_device *bdev,
>> +nouveau_ttm_tt_destroy(struct ttm_device *bdev,
>>                         struct ttm_tt *ttm)
>>   {
>>   #if IS_ENABLED(CONFIG_AGP)
>> @@ -1296,7 +1296,7 @@ nouveau_bo_delete_mem_notify(struct ttm_buffer_object *bo)
>>          nouveau_bo_move_ntfy(bo, false, NULL);
>>   }
>>
>> -struct ttm_bo_driver nouveau_bo_driver = {
>> +struct ttm_device_funcs nouveau_bo_driver = {
>>          .ttm_tt_create = &nouveau_ttm_tt_create,
>>          .ttm_tt_populate = &nouveau_ttm_tt_populate,
>>          .ttm_tt_unpopulate = &nouveau_ttm_tt_unpopulate,
>> diff --git a/drivers/gpu/drm/nouveau/nouveau_bo.h b/drivers/gpu/drm/nouveau/nouveau_bo.h
>> index 6045b85a762a..c2d3f9c48eba 100644
>> --- a/drivers/gpu/drm/nouveau/nouveau_bo.h
>> +++ b/drivers/gpu/drm/nouveau/nouveau_bo.h
>> @@ -68,7 +68,7 @@ nouveau_bo_ref(struct nouveau_bo *ref, struct nouveau_bo **pnvbo)
>>          return 0;
>>   }
>>
>> -extern struct ttm_bo_driver nouveau_bo_driver;
>> +extern struct ttm_device_funcs nouveau_bo_driver;
>>
>>   void nouveau_bo_move_init(struct nouveau_drm *);
>>   struct nouveau_bo *nouveau_bo_alloc(struct nouveau_cli *, u64 *size, int *align,
>> diff --git a/drivers/gpu/drm/nouveau/nouveau_drv.h b/drivers/gpu/drm/nouveau/nouveau_drv.h
>> index c802d3d1ba39..edf9d1ee9d58 100644
>> --- a/drivers/gpu/drm/nouveau/nouveau_drv.h
>> +++ b/drivers/gpu/drm/nouveau/nouveau_drv.h
>> @@ -151,7 +151,7 @@ struct nouveau_drm {
>>
>>          /* TTM interface support */
>>          struct {
>> -               struct ttm_bo_device bdev;
>> +               struct ttm_device bdev;
>>                  atomic_t validate_sequence;
>>                  int (*move)(struct nouveau_channel *,
>>                              struct ttm_buffer_object *,
>> diff --git a/drivers/gpu/drm/nouveau/nouveau_sgdma.c b/drivers/gpu/drm/nouveau/nouveau_sgdma.c
>> index 1cf52635ea74..256ec5b35473 100644
>> --- a/drivers/gpu/drm/nouveau/nouveau_sgdma.c
>> +++ b/drivers/gpu/drm/nouveau/nouveau_sgdma.c
>> @@ -16,7 +16,7 @@ struct nouveau_sgdma_be {
>>   };
>>
>>   void
>> -nouveau_sgdma_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>> +nouveau_sgdma_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>>          struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm;
>>
>> @@ -29,7 +29,7 @@ nouveau_sgdma_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>>   }
>>
>>   int
>> -nouveau_sgdma_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg)
>> +nouveau_sgdma_bind(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg)
>>   {
>>          struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm;
>>          struct nouveau_drm *drm = nouveau_bdev(bdev);
>> @@ -56,7 +56,7 @@ nouveau_sgdma_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_re
>>   }
>>
>>   void
>> -nouveau_sgdma_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>> +nouveau_sgdma_unbind(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>>          struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm;
>>          if (nvbe->mem) {
>> diff --git a/drivers/gpu/drm/nouveau/nouveau_ttm.c b/drivers/gpu/drm/nouveau/nouveau_ttm.c
>> index a37bc3d7b38b..495288182c2d 100644
>> --- a/drivers/gpu/drm/nouveau/nouveau_ttm.c
>> +++ b/drivers/gpu/drm/nouveau/nouveau_ttm.c
>> @@ -324,10 +324,10 @@ nouveau_ttm_init(struct nouveau_drm *drm)
>>          need_swiotlb = !!swiotlb_nr_tbl();
>>   #endif
>>
>> -       ret = ttm_bo_device_init(&drm->ttm.bdev, &nouveau_bo_driver,
>> -                                drm->dev->dev, dev->anon_inode->i_mapping,
>> -                                dev->vma_offset_manager, need_swiotlb,
>> -                                drm->client.mmu.dmabits <= 32);
>> +       ret = ttm_device_init(&drm->ttm.bdev, &nouveau_bo_driver, drm->dev->dev,
>> +                                 dev->anon_inode->i_mapping,
>> +                                 dev->vma_offset_manager, need_swiotlb,
>> +                                 drm->client.mmu.dmabits <= 32);
>>          if (ret) {
>>                  NV_ERROR(drm, "error initialising bo driver, %d\n", ret);
>>                  return ret;
>> @@ -377,7 +377,7 @@ nouveau_ttm_fini(struct nouveau_drm *drm)
>>          nouveau_ttm_fini_vram(drm);
>>          nouveau_ttm_fini_gtt(drm);
>>
>> -       ttm_bo_device_release(&drm->ttm.bdev);
>> +       ttm_device_fini(&drm->ttm.bdev);
>>
>>          arch_phys_wc_del(drm->ttm.mtrr);
>>          drm->ttm.mtrr = 0;
>> diff --git a/drivers/gpu/drm/nouveau/nouveau_ttm.h b/drivers/gpu/drm/nouveau/nouveau_ttm.h
>> index 69552049bb96..dbf6dc238efd 100644
>> --- a/drivers/gpu/drm/nouveau/nouveau_ttm.h
>> +++ b/drivers/gpu/drm/nouveau/nouveau_ttm.h
>> @@ -3,7 +3,7 @@
>>   #define __NOUVEAU_TTM_H__
>>
>>   static inline struct nouveau_drm *
>> -nouveau_bdev(struct ttm_bo_device *bd)
>> +nouveau_bdev(struct ttm_device *bd)
>>   {
>>          return container_of(bd, struct nouveau_drm, ttm.bdev);
>>   }
>> @@ -22,7 +22,7 @@ int  nouveau_ttm_mmap(struct file *, struct vm_area_struct *);
>>   int  nouveau_ttm_global_init(struct nouveau_drm *);
>>   void nouveau_ttm_global_release(struct nouveau_drm *);
>>
>> -int nouveau_sgdma_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg);
>> -void nouveau_sgdma_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>> -void nouveau_sgdma_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>> +int nouveau_sgdma_bind(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg);
>> +void nouveau_sgdma_unbind(struct ttm_device *bdev, struct ttm_tt *ttm);
>> +void nouveau_sgdma_destroy(struct ttm_device *bdev, struct ttm_tt *ttm);
>>   #endif
>> diff --git a/drivers/gpu/drm/qxl/qxl_drv.h b/drivers/gpu/drm/qxl/qxl_drv.h
>> index 83b54f0dad61..01354b43c413 100644
>> --- a/drivers/gpu/drm/qxl/qxl_drv.h
>> +++ b/drivers/gpu/drm/qxl/qxl_drv.h
>> @@ -125,7 +125,7 @@ struct qxl_output {
>>   #define drm_encoder_to_qxl_output(x) container_of(x, struct qxl_output, enc)
>>
>>   struct qxl_mman {
>> -       struct ttm_bo_device            bdev;
>> +       struct ttm_device               bdev;
>>   };
>>
>>   struct qxl_memslot {
>> @@ -335,7 +335,7 @@ int qxl_mode_dumb_mmap(struct drm_file *filp,
>>   /* qxl ttm */
>>   int qxl_ttm_init(struct qxl_device *qdev);
>>   void qxl_ttm_fini(struct qxl_device *qdev);
>> -int qxl_ttm_io_mem_reserve(struct ttm_bo_device *bdev,
>> +int qxl_ttm_io_mem_reserve(struct ttm_device *bdev,
>>                             struct ttm_resource *mem);
>>
>>   /* qxl image */
>> diff --git a/drivers/gpu/drm/qxl/qxl_release.c b/drivers/gpu/drm/qxl/qxl_release.c
>> index 0fcfc952d5e9..c52412724c26 100644
>> --- a/drivers/gpu/drm/qxl/qxl_release.c
>> +++ b/drivers/gpu/drm/qxl/qxl_release.c
>> @@ -429,7 +429,7 @@ void qxl_release_unmap(struct qxl_device *qdev,
>>   void qxl_release_fence_buffer_objects(struct qxl_release *release)
>>   {
>>          struct ttm_buffer_object *bo;
>> -       struct ttm_bo_device *bdev;
>> +       struct ttm_device *bdev;
>>          struct ttm_validate_buffer *entry;
>>          struct qxl_device *qdev;
>>
>> @@ -450,7 +450,7 @@ void qxl_release_fence_buffer_objects(struct qxl_release *release)
>>                         release->id | 0xf0000000, release->base.seqno);
>>          trace_dma_fence_emit(&release->base);
>>
>> -       spin_lock(&ttm_bo_glob.lru_lock);
>> +       spin_lock(&ttm_glob.lru_lock);
>>
>>          list_for_each_entry(entry, &release->bos, head) {
>>                  bo = entry->bo;
>> @@ -459,7 +459,7 @@ void qxl_release_fence_buffer_objects(struct qxl_release *release)
>>                  ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
>>                  dma_resv_unlock(bo->base.resv);
>>          }
>> -       spin_unlock(&ttm_bo_glob.lru_lock);
>> +       spin_unlock(&ttm_glob.lru_lock);
>>          ww_acquire_fini(&release->ticket);
>>   }
>>
>> diff --git a/drivers/gpu/drm/qxl/qxl_ttm.c b/drivers/gpu/drm/qxl/qxl_ttm.c
>> index 33c09dc94f8b..b7f77eb685cb 100644
>> --- a/drivers/gpu/drm/qxl/qxl_ttm.c
>> +++ b/drivers/gpu/drm/qxl/qxl_ttm.c
>> @@ -36,7 +36,7 @@
>>   #include "qxl_drv.h"
>>   #include "qxl_object.h"
>>
>> -static struct qxl_device *qxl_get_qdev(struct ttm_bo_device *bdev)
>> +static struct qxl_device *qxl_get_qdev(struct ttm_device *bdev)
>>   {
>>          struct qxl_mman *mman;
>>          struct qxl_device *qdev;
>> @@ -69,7 +69,7 @@ static void qxl_evict_flags(struct ttm_buffer_object *bo,
>>          *placement = qbo->placement;
>>   }
>>
>> -int qxl_ttm_io_mem_reserve(struct ttm_bo_device *bdev,
>> +int qxl_ttm_io_mem_reserve(struct ttm_device *bdev,
>>                             struct ttm_resource *mem)
>>   {
>>          struct qxl_device *qdev = qxl_get_qdev(bdev);
>> @@ -98,8 +98,7 @@ int qxl_ttm_io_mem_reserve(struct ttm_bo_device *bdev,
>>   /*
>>    * TTM backend functions.
>>    */
>> -static void qxl_ttm_backend_destroy(struct ttm_bo_device *bdev,
>> -                                   struct ttm_tt *ttm)
>> +static void qxl_ttm_backend_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>>          ttm_tt_destroy_common(bdev, ttm);
>>          ttm_tt_fini(ttm);
>> @@ -170,7 +169,7 @@ static void qxl_bo_delete_mem_notify(struct ttm_buffer_object *bo)
>>          qxl_bo_move_notify(bo, false, NULL);
>>   }
>>
>> -static struct ttm_bo_driver qxl_bo_driver = {
>> +static struct ttm_device_funcs qxl_bo_driver = {
>>          .ttm_tt_create = &qxl_ttm_tt_create,
>>          .ttm_tt_destroy = &qxl_ttm_backend_destroy,
>>          .eviction_valuable = ttm_bo_eviction_valuable,
>> @@ -193,10 +192,10 @@ int qxl_ttm_init(struct qxl_device *qdev)
>>          int num_io_pages; /* != rom->num_io_pages, we include surface0 */
>>
>>          /* No others user of address space so set it to 0 */
>> -       r = ttm_bo_device_init(&qdev->mman.bdev, &qxl_bo_driver, NULL,
>> -                              qdev->ddev.anon_inode->i_mapping,
>> -                              qdev->ddev.vma_offset_manager,
>> -                              false, false);
>> +       r = ttm_device_init(&qdev->mman.bdev, &qxl_bo_driver, NULL,
>> +                           qdev->ddev.anon_inode->i_mapping,
>> +                           qdev->ddev.vma_offset_manager,
>> +                           false, false);
>>          if (r) {
>>                  DRM_ERROR("failed initializing buffer object driver(%d).\n", r);
>>                  return r;
>> @@ -227,7 +226,7 @@ void qxl_ttm_fini(struct qxl_device *qdev)
>>   {
>>          ttm_range_man_fini(&qdev->mman.bdev, TTM_PL_VRAM);
>>          ttm_range_man_fini(&qdev->mman.bdev, TTM_PL_PRIV);
>> -       ttm_bo_device_release(&qdev->mman.bdev);
>> +       ttm_device_fini(&qdev->mman.bdev);
>>          DRM_INFO("qxl: ttm finalized\n");
>>   }
>>
>> diff --git a/drivers/gpu/drm/radeon/radeon.h b/drivers/gpu/drm/radeon/radeon.h
>> index f09989bdce98..449ba0095ed9 100644
>> --- a/drivers/gpu/drm/radeon/radeon.h
>> +++ b/drivers/gpu/drm/radeon/radeon.h
>> @@ -451,7 +451,7 @@ struct radeon_surface_reg {
>>    * TTM.
>>    */
>>   struct radeon_mman {
>> -       struct ttm_bo_device            bdev;
>> +       struct ttm_device               bdev;
>>          bool                            initialized;
>>
>>   #if defined(CONFIG_DEBUG_FS)
>> @@ -2822,7 +2822,7 @@ extern int radeon_ttm_tt_set_userptr(struct radeon_device *rdev,
>>                                       uint32_t flags);
>>   extern bool radeon_ttm_tt_has_userptr(struct radeon_device *rdev, struct ttm_tt *ttm);
>>   extern bool radeon_ttm_tt_is_readonly(struct radeon_device *rdev, struct ttm_tt *ttm);
>> -bool radeon_ttm_tt_is_bound(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>> +bool radeon_ttm_tt_is_bound(struct ttm_device *bdev, struct ttm_tt *ttm);
>>   extern void radeon_vram_location(struct radeon_device *rdev, struct radeon_mc *mc, u64 base);
>>   extern void radeon_gtt_location(struct radeon_device *rdev, struct radeon_mc *mc);
>>   extern int radeon_resume_kms(struct drm_device *dev, bool resume, bool fbcon);
>> @@ -2832,7 +2832,7 @@ extern void radeon_ttm_set_active_vram_size(struct radeon_device *rdev, u64 size
>>   extern void radeon_program_register_sequence(struct radeon_device *rdev,
>>                                               const u32 *registers,
>>                                               const u32 array_size);
>> -struct radeon_device *radeon_get_rdev(struct ttm_bo_device *bdev);
>> +struct radeon_device *radeon_get_rdev(struct ttm_device *bdev);
>>
>>   /* KMS */
>>
>> diff --git a/drivers/gpu/drm/radeon/radeon_object.c b/drivers/gpu/drm/radeon/radeon_object.c
>> index 9b81786782de..6a336284466f 100644
>> --- a/drivers/gpu/drm/radeon/radeon_object.c
>> +++ b/drivers/gpu/drm/radeon/radeon_object.c
>> @@ -372,7 +372,7 @@ void radeon_bo_unpin(struct radeon_bo *bo)
>>
>>   int radeon_bo_evict_vram(struct radeon_device *rdev)
>>   {
>> -       struct ttm_bo_device *bdev = &rdev->mman.bdev;
>> +       struct ttm_device *bdev = &rdev->mman.bdev;
>>          struct ttm_resource_manager *man;
>>
>>          /* late 2.6.33 fix IGP hibernate - we need pm ops to do this correct */
>> diff --git a/drivers/gpu/drm/radeon/radeon_ttm.c b/drivers/gpu/drm/radeon/radeon_ttm.c
>> index c6d575f50c48..5ed6a48246d6 100644
>> --- a/drivers/gpu/drm/radeon/radeon_ttm.c
>> +++ b/drivers/gpu/drm/radeon/radeon_ttm.c
>> @@ -55,13 +55,11 @@
>>   static int radeon_ttm_debugfs_init(struct radeon_device *rdev);
>>   static void radeon_ttm_debugfs_fini(struct radeon_device *rdev);
>>
>> -static int radeon_ttm_tt_bind(struct ttm_bo_device *bdev,
>> -                             struct ttm_tt *ttm,
>> +static int radeon_ttm_tt_bind(struct ttm_device *bdev, struct ttm_tt *ttm,
>>                                struct ttm_resource *bo_mem);
>> -static void radeon_ttm_tt_unbind(struct ttm_bo_device *bdev,
>> -                                struct ttm_tt *ttm);
>> +static void radeon_ttm_tt_unbind(struct ttm_device *bdev, struct ttm_tt *ttm);
>>
>> -struct radeon_device *radeon_get_rdev(struct ttm_bo_device *bdev)
>> +struct radeon_device *radeon_get_rdev(struct ttm_device *bdev)
>>   {
>>          struct radeon_mman *mman;
>>          struct radeon_device *rdev;
>> @@ -280,7 +278,7 @@ static int radeon_bo_move(struct ttm_buffer_object *bo, bool evict,
>>          return 0;
>>   }
>>
>> -static int radeon_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *mem)
>> +static int radeon_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *mem)
>>   {
>>          struct radeon_device *rdev = radeon_get_rdev(bdev);
>>          size_t bus_size = (size_t)mem->num_pages << PAGE_SHIFT;
>> @@ -347,7 +345,7 @@ struct radeon_ttm_tt {
>>   };
>>
>>   /* prepare the sg table with the user pages */
>> -static int radeon_ttm_tt_pin_userptr(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>> +static int radeon_ttm_tt_pin_userptr(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>>          struct radeon_device *rdev = radeon_get_rdev(bdev);
>>          struct radeon_ttm_tt *gtt = (void *)ttm;
>> @@ -408,7 +406,7 @@ static int radeon_ttm_tt_pin_userptr(struct ttm_bo_device *bdev, struct ttm_tt *
>>          return r;
>>   }
>>
>> -static void radeon_ttm_tt_unpin_userptr(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>> +static void radeon_ttm_tt_unpin_userptr(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>>          struct radeon_device *rdev = radeon_get_rdev(bdev);
>>          struct radeon_ttm_tt *gtt = (void *)ttm;
>> @@ -444,7 +442,7 @@ static bool radeon_ttm_backend_is_bound(struct ttm_tt *ttm)
>>          return (gtt->bound);
>>   }
>>
>> -static int radeon_ttm_backend_bind(struct ttm_bo_device *bdev,
>> +static int radeon_ttm_backend_bind(struct ttm_device *bdev,
>>                                     struct ttm_tt *ttm,
>>                                     struct ttm_resource *bo_mem)
>>   {
>> @@ -480,7 +478,7 @@ static int radeon_ttm_backend_bind(struct ttm_bo_device *bdev,
>>          return 0;
>>   }
>>
>> -static void radeon_ttm_backend_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>> +static void radeon_ttm_backend_unbind(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>>          struct radeon_ttm_tt *gtt = (void *)ttm;
>>          struct radeon_device *rdev = radeon_get_rdev(bdev);
>> @@ -495,7 +493,7 @@ static void radeon_ttm_backend_unbind(struct ttm_bo_device *bdev, struct ttm_tt
>>          gtt->bound = false;
>>   }
>>
>> -static void radeon_ttm_backend_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>> +static void radeon_ttm_backend_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>>          struct radeon_ttm_tt *gtt = (void *)ttm;
>>
>> @@ -554,7 +552,7 @@ static struct radeon_ttm_tt *radeon_ttm_tt_to_gtt(struct radeon_device *rdev,
>>          return container_of(ttm, struct radeon_ttm_tt, ttm);
>>   }
>>
>> -static int radeon_ttm_tt_populate(struct ttm_bo_device *bdev,
>> +static int radeon_ttm_tt_populate(struct ttm_device *bdev,
>>                                    struct ttm_tt *ttm,
>>                                    struct ttm_operation_ctx *ctx)
>>   {
>> @@ -580,7 +578,7 @@ static int radeon_ttm_tt_populate(struct ttm_bo_device *bdev,
>>          return ttm_pool_alloc(&rdev->mman.bdev.pool, ttm, ctx);
>>   }
>>
>> -static void radeon_ttm_tt_unpopulate(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>> +static void radeon_ttm_tt_unpopulate(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>>          struct radeon_device *rdev = radeon_get_rdev(bdev);
>>          struct radeon_ttm_tt *gtt = radeon_ttm_tt_to_gtt(rdev, ttm);
>> @@ -613,7 +611,7 @@ int radeon_ttm_tt_set_userptr(struct radeon_device *rdev,
>>          return 0;
>>   }
>>
>> -bool radeon_ttm_tt_is_bound(struct ttm_bo_device *bdev,
>> +bool radeon_ttm_tt_is_bound(struct ttm_device *bdev,
>>                              struct ttm_tt *ttm)
>>   {
>>   #if IS_ENABLED(CONFIG_AGP)
>> @@ -624,7 +622,7 @@ bool radeon_ttm_tt_is_bound(struct ttm_bo_device *bdev,
>>          return radeon_ttm_backend_is_bound(ttm);
>>   }
>>
>> -static int radeon_ttm_tt_bind(struct ttm_bo_device *bdev,
>> +static int radeon_ttm_tt_bind(struct ttm_device *bdev,
>>                                struct ttm_tt *ttm,
>>                                struct ttm_resource *bo_mem)
>>   {
>> @@ -642,7 +640,7 @@ static int radeon_ttm_tt_bind(struct ttm_bo_device *bdev,
>>          return radeon_ttm_backend_bind(bdev, ttm, bo_mem);
>>   }
>>
>> -static void radeon_ttm_tt_unbind(struct ttm_bo_device *bdev,
>> +static void radeon_ttm_tt_unbind(struct ttm_device *bdev,
>>                                   struct ttm_tt *ttm)
>>   {
>>   #if IS_ENABLED(CONFIG_AGP)
>> @@ -656,7 +654,7 @@ static void radeon_ttm_tt_unbind(struct ttm_bo_device *bdev,
>>          radeon_ttm_backend_unbind(bdev, ttm);
>>   }
>>
>> -static void radeon_ttm_tt_destroy(struct ttm_bo_device *bdev,
>> +static void radeon_ttm_tt_destroy(struct ttm_device *bdev,
>>                                    struct ttm_tt *ttm)
>>   {
>>   #if IS_ENABLED(CONFIG_AGP)
>> @@ -700,7 +698,7 @@ radeon_bo_delete_mem_notify(struct ttm_buffer_object *bo)
>>          radeon_bo_move_notify(bo, false, NULL);
>>   }
>>
>> -static struct ttm_bo_driver radeon_bo_driver = {
>> +static struct ttm_device_funcs radeon_bo_driver = {
>>          .ttm_tt_create = &radeon_ttm_tt_create,
>>          .ttm_tt_populate = &radeon_ttm_tt_populate,
>>          .ttm_tt_unpopulate = &radeon_ttm_tt_unpopulate,
>> @@ -718,7 +716,7 @@ int radeon_ttm_init(struct radeon_device *rdev)
>>          int r;
>>
>>          /* No others user of address space so set it to 0 */
>> -       r = ttm_bo_device_init(&rdev->mman.bdev, &radeon_bo_driver, rdev->dev,
>> +       r = ttm_device_init(&rdev->mman.bdev, &radeon_bo_driver, rdev->dev,
>>                                 rdev->ddev->anon_inode->i_mapping,
>>                                 rdev->ddev->vma_offset_manager,
>>                                 rdev->need_swiotlb,
>> @@ -791,7 +789,7 @@ void radeon_ttm_fini(struct radeon_device *rdev)
>>          }
>>          ttm_range_man_fini(&rdev->mman.bdev, TTM_PL_VRAM);
>>          ttm_range_man_fini(&rdev->mman.bdev, TTM_PL_TT);
>> -       ttm_bo_device_release(&rdev->mman.bdev);
>> +       ttm_device_fini(&rdev->mman.bdev);
>>          radeon_gart_fini(rdev);
>>          rdev->mman.initialized = false;
>>          DRM_INFO("radeon: ttm finalized\n");
>> diff --git a/drivers/gpu/drm/ttm/Makefile b/drivers/gpu/drm/ttm/Makefile
>> index b6f5f87b270f..8e6437eadabe 100644
>> --- a/drivers/gpu/drm/ttm/Makefile
>> +++ b/drivers/gpu/drm/ttm/Makefile
>> @@ -5,7 +5,7 @@
>>   ttm-y := ttm_memory.o ttm_tt.o ttm_bo.o \
>>          ttm_bo_util.o ttm_bo_vm.o ttm_module.o \
>>          ttm_execbuf_util.o ttm_range_manager.o \
>> -       ttm_resource.o ttm_pool.o
>> +       ttm_resource.o ttm_pool.o ttm_device.o
>>   ttm-$(CONFIG_AGP) += ttm_agp_backend.o
>>
>>   obj-$(CONFIG_DRM_TTM) += ttm.o
>> diff --git a/drivers/gpu/drm/ttm/ttm_agp_backend.c b/drivers/gpu/drm/ttm/ttm_agp_backend.c
>> index 8f9fa4188897..0226ae69d3ab 100644
>> --- a/drivers/gpu/drm/ttm/ttm_agp_backend.c
>> +++ b/drivers/gpu/drm/ttm/ttm_agp_backend.c
>> @@ -49,7 +49,7 @@ struct ttm_agp_backend {
>>   int ttm_agp_bind(struct ttm_tt *ttm, struct ttm_resource *bo_mem)
>>   {
>>          struct ttm_agp_backend *agp_be = container_of(ttm, struct ttm_agp_backend, ttm);
>> -       struct page *dummy_read_page = ttm_bo_glob.dummy_read_page;
>> +       struct page *dummy_read_page = ttm_glob.dummy_read_page;
>>          struct drm_mm_node *node = bo_mem->mm_node;
>>          struct agp_memory *mem;
>>          int ret, cached = ttm->caching == ttm_cached;
>> diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c
>> index c289a6a37ff9..20256797f3a6 100644
>> --- a/drivers/gpu/drm/ttm/ttm_bo.c
>> +++ b/drivers/gpu/drm/ttm/ttm_bo.c
>> @@ -44,14 +44,6 @@
>>
>>   #include "ttm_module.h"
>>
>> -/*
>> - * ttm_global_mutex - protecting the global BO state
>> - */
>> -DEFINE_MUTEX(ttm_global_mutex);
>> -unsigned ttm_bo_glob_use_count;
>> -struct ttm_bo_global ttm_bo_glob;
>> -EXPORT_SYMBOL(ttm_bo_glob);
>> -
>>   /* default destructor */
>>   static void ttm_bo_default_destroy(struct ttm_buffer_object *bo)
>>   {
>> @@ -79,13 +71,13 @@ static void ttm_bo_mem_space_debug(struct ttm_buffer_object *bo,
>>
>>   static void ttm_bo_del_from_lru(struct ttm_buffer_object *bo)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>
>>          list_del_init(&bo->swap);
>>          list_del_init(&bo->lru);
>>
>> -       if (bdev->driver->del_from_lru_notify)
>> -               bdev->driver->del_from_lru_notify(bo);
>> +       if (bdev->funcs->del_from_lru_notify)
>> +               bdev->funcs->del_from_lru_notify(bo);
>>   }
>>
>>   static void ttm_bo_bulk_move_set_pos(struct ttm_lru_bulk_move_pos *pos,
>> @@ -100,7 +92,7 @@ void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
>>                               struct ttm_resource *mem,
>>                               struct ttm_lru_bulk_move *bulk)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>          struct ttm_resource_manager *man;
>>
>>          dma_resv_assert_held(bo->base.resv);
>> @@ -117,12 +109,12 @@ void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
>>                                       TTM_PAGE_FLAG_SWAPPED))) {
>>                  struct list_head *swap;
>>
>> -               swap = &ttm_bo_glob.swap_lru[bo->priority];
>> +               swap = &ttm_glob.swap_lru[bo->priority];
>>                  list_move_tail(&bo->swap, swap);
>>          }
>>
>> -       if (bdev->driver->del_from_lru_notify)
>> -               bdev->driver->del_from_lru_notify(bo);
>> +       if (bdev->funcs->del_from_lru_notify)
>> +               bdev->funcs->del_from_lru_notify(bo);
>>
>>          if (bulk && !bo->pin_count) {
>>                  switch (bo->mem.mem_type) {
>> @@ -185,7 +177,7 @@ void ttm_bo_bulk_move_lru_tail(struct ttm_lru_bulk_move *bulk)
>>                  dma_resv_assert_held(pos->first->base.resv);
>>                  dma_resv_assert_held(pos->last->base.resv);
>>
>> -               lru = &ttm_bo_glob.swap_lru[i];
>> +               lru = &ttm_glob.swap_lru[i];
>>                  list_bulk_move_tail(lru, &pos->first->swap, &pos->last->swap);
>>          }
>>   }
>> @@ -196,7 +188,7 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
>>                                    struct ttm_operation_ctx *ctx,
>>                                    struct ttm_place *hop)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>          struct ttm_resource_manager *old_man = ttm_manager_type(bdev, bo->mem.mem_type);
>>          struct ttm_resource_manager *new_man = ttm_manager_type(bdev, mem->mem_type);
>>          int ret;
>> @@ -222,7 +214,7 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
>>                  }
>>          }
>>
>> -       ret = bdev->driver->move(bo, evict, ctx, mem, hop);
>> +       ret = bdev->funcs->move(bo, evict, ctx, mem, hop);
>>          if (ret) {
>>                  if (ret == -EMULTIHOP)
>>                          return ret;
>> @@ -250,8 +242,8 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
>>
>>   static void ttm_bo_cleanup_memtype_use(struct ttm_buffer_object *bo)
>>   {
>> -       if (bo->bdev->driver->delete_mem_notify)
>> -               bo->bdev->driver->delete_mem_notify(bo);
>> +       if (bo->bdev->funcs->delete_mem_notify)
>> +               bo->bdev->funcs->delete_mem_notify(bo);
>>
>>          ttm_bo_tt_destroy(bo);
>>          ttm_resource_free(bo, &bo->mem);
>> @@ -276,9 +268,9 @@ static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
>>                   * 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);
>> +               spin_lock(&ttm_glob.lru_lock);
>>                  bo->base.resv = &bo->base._resv;
>> -               spin_unlock(&ttm_bo_glob.lru_lock);
>> +               spin_unlock(&ttm_glob.lru_lock);
>>          }
>>
>>          return r;
>> @@ -337,7 +329,7 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>>
>>                  if (unlock_resv)
>>                          dma_resv_unlock(bo->base.resv);
>> -               spin_unlock(&ttm_bo_glob.lru_lock);
>> +               spin_unlock(&ttm_glob.lru_lock);
>>
>>                  lret = dma_resv_wait_timeout_rcu(resv, true, interruptible,
>>                                                   30 * HZ);
>> @@ -347,7 +339,7 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>>                  else if (lret == 0)
>>                          return -EBUSY;
>>
>> -               spin_lock(&ttm_bo_glob.lru_lock);
>> +               spin_lock(&ttm_glob.lru_lock);
>>                  if (unlock_resv && !dma_resv_trylock(bo->base.resv)) {
>>                          /*
>>                           * We raced, and lost, someone else holds the reservation now,
>> @@ -357,7 +349,7 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>>                           * delayed destruction would succeed, so just return success
>>                           * here.
>>                           */
>> -                       spin_unlock(&ttm_bo_glob.lru_lock);
>> +                       spin_unlock(&ttm_glob.lru_lock);
>>                          return 0;
>>                  }
>>                  ret = 0;
>> @@ -366,13 +358,13 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>>          if (ret || unlikely(list_empty(&bo->ddestroy))) {
>>                  if (unlock_resv)
>>                          dma_resv_unlock(bo->base.resv);
>> -               spin_unlock(&ttm_bo_glob.lru_lock);
>> +               spin_unlock(&ttm_glob.lru_lock);
>>                  return ret;
>>          }
>>
>>          ttm_bo_del_from_lru(bo);
>>          list_del_init(&bo->ddestroy);
>> -       spin_unlock(&ttm_bo_glob.lru_lock);
>> +       spin_unlock(&ttm_glob.lru_lock);
>>          ttm_bo_cleanup_memtype_use(bo);
>>
>>          if (unlock_resv)
>> @@ -387,9 +379,9 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>>    * Traverse the delayed list, and call ttm_bo_cleanup_refs on all
>>    * encountered buffers.
>>    */
>> -static bool ttm_bo_delayed_delete(struct ttm_bo_device *bdev, bool remove_all)
>> +bool ttm_bo_delayed_delete(struct ttm_device *bdev, bool remove_all)
>>   {
>> -       struct ttm_bo_global *glob = &ttm_bo_glob;
>> +       struct ttm_global *glob = &ttm_glob;
>>          struct list_head removed;
>>          bool empty;
>>
>> @@ -428,21 +420,11 @@ static bool ttm_bo_delayed_delete(struct ttm_bo_device *bdev, bool remove_all)
>>          return empty;
>>   }
>>
>> -static void ttm_bo_delayed_workqueue(struct work_struct *work)
>> -{
>> -       struct ttm_bo_device *bdev =
>> -           container_of(work, struct ttm_bo_device, wq.work);
>> -
>> -       if (!ttm_bo_delayed_delete(bdev, false))
>> -               schedule_delayed_work(&bdev->wq,
>> -                                     ((HZ / 100) < 1) ? 1 : HZ / 100);
>> -}
>> -
>>   static void ttm_bo_release(struct kref *kref)
>>   {
>>          struct ttm_buffer_object *bo =
>>              container_of(kref, struct ttm_buffer_object, kref);
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>          size_t acc_size = bo->acc_size;
>>          int ret;
>>
>> @@ -456,8 +438,8 @@ static void ttm_bo_release(struct kref *kref)
>>                                                    30 * HZ);
>>                  }
>>
>> -               if (bo->bdev->driver->release_notify)
>> -                       bo->bdev->driver->release_notify(bo);
>> +               if (bo->bdev->funcs->release_notify)
>> +                       bo->bdev->funcs->release_notify(bo);
>>
>>                  drm_vma_offset_remove(bdev->vma_manager, &bo->base.vma_node);
>>                  ttm_mem_io_free(bdev, &bo->mem);
>> @@ -469,7 +451,7 @@ static void ttm_bo_release(struct kref *kref)
>>                  ttm_bo_flush_all_fences(bo);
>>                  bo->deleted = true;
>>
>> -               spin_lock(&ttm_bo_glob.lru_lock);
>> +               spin_lock(&ttm_glob.lru_lock);
>>
>>                  /*
>>                   * Make pinned bos immediately available to
>> @@ -483,22 +465,22 @@ static void ttm_bo_release(struct kref *kref)
>>
>>                  kref_init(&bo->kref);
>>                  list_add_tail(&bo->ddestroy, &bdev->ddestroy);
>> -               spin_unlock(&ttm_bo_glob.lru_lock);
>> +               spin_unlock(&ttm_glob.lru_lock);
>>
>>                  schedule_delayed_work(&bdev->wq,
>>                                        ((HZ / 100) < 1) ? 1 : HZ / 100);
>>                  return;
>>          }
>>
>> -       spin_lock(&ttm_bo_glob.lru_lock);
>> +       spin_lock(&ttm_glob.lru_lock);
>>          ttm_bo_del_from_lru(bo);
>>          list_del(&bo->ddestroy);
>> -       spin_unlock(&ttm_bo_glob.lru_lock);
>> +       spin_unlock(&ttm_glob.lru_lock);
>>
>>          ttm_bo_cleanup_memtype_use(bo);
>>          dma_resv_unlock(bo->base.resv);
>>
>> -       atomic_dec(&ttm_bo_glob.bo_count);
>> +       atomic_dec(&ttm_glob.bo_count);
>>          dma_fence_put(bo->moving);
>>          if (!ttm_bo_uses_embedded_gem_object(bo))
>>                  dma_resv_fini(&bo->base._resv);
>> @@ -512,13 +494,13 @@ void ttm_bo_put(struct ttm_buffer_object *bo)
>>   }
>>   EXPORT_SYMBOL(ttm_bo_put);
>>
>> -int ttm_bo_lock_delayed_workqueue(struct ttm_bo_device *bdev)
>> +int ttm_bo_lock_delayed_workqueue(struct ttm_device *bdev)
>>   {
>>          return cancel_delayed_work_sync(&bdev->wq);
>>   }
>>   EXPORT_SYMBOL(ttm_bo_lock_delayed_workqueue);
>>
>> -void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev, int resched)
>> +void ttm_bo_unlock_delayed_workqueue(struct ttm_device *bdev, int resched)
>>   {
>>          if (resched)
>>                  schedule_delayed_work(&bdev->wq,
>> @@ -529,7 +511,7 @@ EXPORT_SYMBOL(ttm_bo_unlock_delayed_workqueue);
>>   static int ttm_bo_evict(struct ttm_buffer_object *bo,
>>                          struct ttm_operation_ctx *ctx)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>          struct ttm_resource evict_mem;
>>          struct ttm_placement placement;
>>          struct ttm_place hop;
>> @@ -541,7 +523,7 @@ static int ttm_bo_evict(struct ttm_buffer_object *bo,
>>
>>          placement.num_placement = 0;
>>          placement.num_busy_placement = 0;
>> -       bdev->driver->evict_flags(bo, &placement);
>> +       bdev->funcs->evict_flags(bo, &placement);
>>
>>          if (!placement.num_placement && !placement.num_busy_placement) {
>>                  ttm_bo_wait(bo, false, false);
>> @@ -657,7 +639,7 @@ static int ttm_mem_evict_wait_busy(struct ttm_buffer_object *busy_bo,
>>          return r == -EDEADLK ? -EBUSY : r;
>>   }
>>
>> -int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>> +int ttm_mem_evict_first(struct ttm_device *bdev,
>>                          struct ttm_resource_manager *man,
>>                          const struct ttm_place *place,
>>                          struct ttm_operation_ctx *ctx,
>> @@ -668,7 +650,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>>          unsigned i;
>>          int ret;
>>
>> -       spin_lock(&ttm_bo_glob.lru_lock);
>> +       spin_lock(&ttm_glob.lru_lock);
>>          for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i) {
>>                  list_for_each_entry(bo, &man->lru[i], lru) {
>>                          bool busy;
>> @@ -681,7 +663,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>>                                  continue;
>>                          }
>>
>> -                       if (place && !bdev->driver->eviction_valuable(bo,
>> +                       if (place && !bdev->funcs->eviction_valuable(bo,
>>                                                                        place)) {
>>                                  if (locked)
>>                                          dma_resv_unlock(bo->base.resv);
>> @@ -705,7 +687,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>>          if (!bo) {
>>                  if (busy_bo && !ttm_bo_get_unless_zero(busy_bo))
>>                          busy_bo = NULL;
>> -               spin_unlock(&ttm_bo_glob.lru_lock);
>> +               spin_unlock(&ttm_glob.lru_lock);
>>                  ret = ttm_mem_evict_wait_busy(busy_bo, ctx, ticket);
>>                  if (busy_bo)
>>                          ttm_bo_put(busy_bo);
>> @@ -719,7 +701,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>>                  return ret;
>>          }
>>
>> -       spin_unlock(&ttm_bo_glob.lru_lock);
>> +       spin_unlock(&ttm_glob.lru_lock);
>>
>>          ret = ttm_bo_evict(bo, ctx);
>>          if (locked)
>> @@ -774,7 +756,7 @@ static int ttm_bo_mem_force_space(struct ttm_buffer_object *bo,
>>                                    struct ttm_resource *mem,
>>                                    struct ttm_operation_ctx *ctx)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>          struct ttm_resource_manager *man = ttm_manager_type(bdev, mem->mem_type);
>>          struct ww_acquire_ctx *ticket;
>>          int ret;
>> @@ -809,7 +791,7 @@ static int ttm_bo_mem_placement(struct ttm_buffer_object *bo,
>>                                  const struct ttm_place *place,
>>                                  struct ttm_resource *mem)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>          struct ttm_resource_manager *man;
>>
>>          man = ttm_manager_type(bdev, place->mem_type);
>> @@ -819,9 +801,9 @@ static int ttm_bo_mem_placement(struct ttm_buffer_object *bo,
>>          mem->mem_type = place->mem_type;
>>          mem->placement = place->flags;
>>
>> -       spin_lock(&ttm_bo_glob.lru_lock);
>> +       spin_lock(&ttm_glob.lru_lock);
>>          ttm_bo_move_to_lru_tail(bo, mem, NULL);
>> -       spin_unlock(&ttm_bo_glob.lru_lock);
>> +       spin_unlock(&ttm_glob.lru_lock);
>>
>>          return 0;
>>   }
>> @@ -839,7 +821,7 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
>>                          struct ttm_resource *mem,
>>                          struct ttm_operation_ctx *ctx)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>          bool type_found = false;
>>          int i, ret;
>>
>> @@ -1057,7 +1039,7 @@ int ttm_bo_validate(struct ttm_buffer_object *bo,
>>   }
>>   EXPORT_SYMBOL(ttm_bo_validate);
>>
>> -int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>> +int ttm_bo_init_reserved(struct ttm_device *bdev,
>>                           struct ttm_buffer_object *bo,
>>                           size_t size,
>>                           enum ttm_bo_type type,
>> @@ -1117,7 +1099,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>>                  dma_resv_init(&bo->base._resv);
>>                  drm_vma_node_reset(&bo->base.vma_node);
>>          }
>> -       atomic_inc(&ttm_bo_glob.bo_count);
>> +       atomic_inc(&ttm_glob.bo_count);
>>
>>          /*
>>           * For ttm_bo_type_device buffers, allocate
>> @@ -1153,7 +1135,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>>   }
>>   EXPORT_SYMBOL(ttm_bo_init_reserved);
>>
>> -int ttm_bo_init(struct ttm_bo_device *bdev,
>> +int ttm_bo_init(struct ttm_device *bdev,
>>                  struct ttm_buffer_object *bo,
>>                  size_t size,
>>                  enum ttm_bo_type type,
>> @@ -1181,7 +1163,7 @@ int ttm_bo_init(struct ttm_bo_device *bdev,
>>   }
>>   EXPORT_SYMBOL(ttm_bo_init);
>>
>> -size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
>> +size_t ttm_bo_dma_acc_size(struct ttm_device *bdev,
>>                             unsigned long bo_size,
>>                             unsigned struct_size)
>>   {
>> @@ -1195,148 +1177,13 @@ size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
>>   }
>>   EXPORT_SYMBOL(ttm_bo_dma_acc_size);
>>
>> -static void ttm_bo_global_release(void)
>> -{
>> -       struct ttm_bo_global *glob = &ttm_bo_glob;
>> -
>> -       mutex_lock(&ttm_global_mutex);
>> -       if (--ttm_bo_glob_use_count > 0)
>> -               goto out;
>> -
>> -       kobject_del(&glob->kobj);
>> -       kobject_put(&glob->kobj);
>> -       ttm_mem_global_release(&ttm_mem_glob);
>> -       __free_page(glob->dummy_read_page);
>> -       memset(glob, 0, sizeof(*glob));
>> -out:
>> -       mutex_unlock(&ttm_global_mutex);
>> -}
>> -
>> -static int ttm_bo_global_init(void)
>> -{
>> -       struct ttm_bo_global *glob = &ttm_bo_glob;
>> -       int ret = 0;
>> -       unsigned i;
>> -
>> -       mutex_lock(&ttm_global_mutex);
>> -       if (++ttm_bo_glob_use_count > 1)
>> -               goto out;
>> -
>> -       ret = ttm_mem_global_init(&ttm_mem_glob);
>> -       if (ret)
>> -               goto out;
>> -
>> -       spin_lock_init(&glob->lru_lock);
>> -       glob->dummy_read_page = alloc_page(__GFP_ZERO | GFP_DMA32);
>> -
>> -       if (unlikely(glob->dummy_read_page == NULL)) {
>> -               ret = -ENOMEM;
>> -               goto out;
>> -       }
>> -
>> -       for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
>> -               INIT_LIST_HEAD(&glob->swap_lru[i]);
>> -       INIT_LIST_HEAD(&glob->device_list);
>> -       atomic_set(&glob->bo_count, 0);
>> -
>> -       debugfs_create_atomic_t("buffer_objects", 0444, ttm_debugfs_root,
>> -                               &glob->bo_count);
>> -out:
>> -       mutex_unlock(&ttm_global_mutex);
>> -       return ret;
>> -}
>> -
>> -int ttm_bo_device_release(struct ttm_bo_device *bdev)
>> -{
>> -       struct ttm_bo_global *glob = &ttm_bo_glob;
>> -       int ret = 0;
>> -       unsigned i;
>> -       struct ttm_resource_manager *man;
>> -
>> -       man = ttm_manager_type(bdev, TTM_PL_SYSTEM);
>> -       ttm_resource_manager_set_used(man, false);
>> -       ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, NULL);
>> -
>> -       mutex_lock(&ttm_global_mutex);
>> -       list_del(&bdev->device_list);
>> -       mutex_unlock(&ttm_global_mutex);
>> -
>> -       cancel_delayed_work_sync(&bdev->wq);
>> -
>> -       if (ttm_bo_delayed_delete(bdev, true))
>> -               pr_debug("Delayed destroy list was clean\n");
>> -
>> -       spin_lock(&glob->lru_lock);
>> -       for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
>> -               if (list_empty(&man->lru[0]))
>> -                       pr_debug("Swap list %d was clean\n", i);
>> -       spin_unlock(&glob->lru_lock);
>> -
>> -       ttm_pool_fini(&bdev->pool);
>> -
>> -       if (!ret)
>> -               ttm_bo_global_release();
>> -
>> -       return ret;
>> -}
>> -EXPORT_SYMBOL(ttm_bo_device_release);
>> -
>> -static void ttm_bo_init_sysman(struct ttm_bo_device *bdev)
>> -{
>> -       struct ttm_resource_manager *man = &bdev->sysman;
>> -
>> -       /*
>> -        * Initialize the system memory buffer type.
>> -        * Other types need to be driver / IOCTL initialized.
>> -        */
>> -       man->use_tt = true;
>> -
>> -       ttm_resource_manager_init(man, 0);
>> -       ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, man);
>> -       ttm_resource_manager_set_used(man, true);
>> -}
>> -
>> -int ttm_bo_device_init(struct ttm_bo_device *bdev,
>> -                      struct ttm_bo_driver *driver,
>> -                      struct device *dev,
>> -                      struct address_space *mapping,
>> -                      struct drm_vma_offset_manager *vma_manager,
>> -                      bool use_dma_alloc, bool use_dma32)
>> -{
>> -       struct ttm_bo_global *glob = &ttm_bo_glob;
>> -       int ret;
>> -
>> -       if (WARN_ON(vma_manager == NULL))
>> -               return -EINVAL;
>> -
>> -       ret = ttm_bo_global_init();
>> -       if (ret)
>> -               return ret;
>> -
>> -       bdev->driver = driver;
>> -
>> -       ttm_bo_init_sysman(bdev);
>> -       ttm_pool_init(&bdev->pool, dev, use_dma_alloc, use_dma32);
>> -
>> -       bdev->vma_manager = vma_manager;
>> -       INIT_DELAYED_WORK(&bdev->wq, ttm_bo_delayed_workqueue);
>> -       INIT_LIST_HEAD(&bdev->ddestroy);
>> -       bdev->dev_mapping = mapping;
>> -       mutex_lock(&ttm_global_mutex);
>> -       list_add_tail(&bdev->device_list, &glob->device_list);
>> -       mutex_unlock(&ttm_global_mutex);
>> -
>> -       return 0;
>> -}
>> -EXPORT_SYMBOL(ttm_bo_device_init);
>> -
>>   /*
>>    * buffer object vm functions.
>>    */
>>
>>   void ttm_bo_unmap_virtual(struct ttm_buffer_object *bo)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>
>>          drm_vma_node_unmap(&bo->base.vma_node, bdev->dev_mapping);
>>          ttm_mem_io_free(bdev, &bo->mem);
>> @@ -1374,7 +1221,7 @@ EXPORT_SYMBOL(ttm_bo_wait);
>>    */
>>   int ttm_bo_swapout(struct ttm_operation_ctx *ctx)
>>   {
>> -       struct ttm_bo_global *glob = &ttm_bo_glob;
>> +       struct ttm_global *glob = &ttm_glob;
>>          struct ttm_buffer_object *bo;
>>          int ret = -EBUSY;
>>          bool locked;
>> @@ -1452,8 +1299,8 @@ int ttm_bo_swapout(struct ttm_operation_ctx *ctx)
>>           * anyone tries to access a ttm page.
>>           */
>>
>> -       if (bo->bdev->driver->swap_notify)
>> -               bo->bdev->driver->swap_notify(bo);
>> +       if (bo->bdev->funcs->swap_notify)
>> +               bo->bdev->funcs->swap_notify(bo);
>>
>>          ret = ttm_tt_swapout(bo->bdev, bo->ttm);
>>   out:
>> @@ -1478,4 +1325,3 @@ void ttm_bo_tt_destroy(struct ttm_buffer_object *bo)
>>          ttm_tt_destroy(bo->bdev, bo->ttm);
>>          bo->ttm = NULL;
>>   }
>> -
>> diff --git a/drivers/gpu/drm/ttm/ttm_bo_util.c b/drivers/gpu/drm/ttm/ttm_bo_util.c
>> index 398d5013fc39..db0f2661d504 100644
>> --- a/drivers/gpu/drm/ttm/ttm_bo_util.c
>> +++ b/drivers/gpu/drm/ttm/ttm_bo_util.c
>> @@ -46,33 +46,33 @@ struct ttm_transfer_obj {
>>          struct ttm_buffer_object *bo;
>>   };
>>
>> -int ttm_mem_io_reserve(struct ttm_bo_device *bdev,
>> +int ttm_mem_io_reserve(struct ttm_device *bdev,
>>                         struct ttm_resource *mem)
>>   {
>>          if (mem->bus.offset || mem->bus.addr)
>>                  return 0;
>>
>>          mem->bus.is_iomem = false;
>> -       if (!bdev->driver->io_mem_reserve)
>> +       if (!bdev->funcs->io_mem_reserve)
>>                  return 0;
>>
>> -       return bdev->driver->io_mem_reserve(bdev, mem);
>> +       return bdev->funcs->io_mem_reserve(bdev, mem);
>>   }
>>
>> -void ttm_mem_io_free(struct ttm_bo_device *bdev,
>> +void ttm_mem_io_free(struct ttm_device *bdev,
>>                       struct ttm_resource *mem)
>>   {
>>          if (!mem->bus.offset && !mem->bus.addr)
>>                  return;
>>
>> -       if (bdev->driver->io_mem_free)
>> -               bdev->driver->io_mem_free(bdev, mem);
>> +       if (bdev->funcs->io_mem_free)
>> +               bdev->funcs->io_mem_free(bdev, mem);
>>
>>          mem->bus.offset = 0;
>>          mem->bus.addr = NULL;
>>   }
>>
>> -static int ttm_resource_ioremap(struct ttm_bo_device *bdev,
>> +static int ttm_resource_ioremap(struct ttm_device *bdev,
>>                                 struct ttm_resource *mem,
>>                                 void **virtual)
>>   {
>> @@ -102,7 +102,7 @@ static int ttm_resource_ioremap(struct ttm_bo_device *bdev,
>>          return 0;
>>   }
>>
>> -static void ttm_resource_iounmap(struct ttm_bo_device *bdev,
>> +static void ttm_resource_iounmap(struct ttm_device *bdev,
>>                                  struct ttm_resource *mem,
>>                                  void *virtual)
>>   {
>> @@ -172,7 +172,7 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo,
>>                         struct ttm_operation_ctx *ctx,
>>                         struct ttm_resource *new_mem)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>          struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type);
>>          struct ttm_tt *ttm = bo->ttm;
>>          struct ttm_resource *old_mem = &bo->mem;
>> @@ -300,7 +300,7 @@ static int ttm_buffer_object_transfer(struct ttm_buffer_object *bo,
>>           * TODO: Explicit member copy would probably be better here.
>>           */
>>
>> -       atomic_inc(&ttm_bo_glob.bo_count);
>> +       atomic_inc(&ttm_glob.bo_count);
>>          INIT_LIST_HEAD(&fbo->base.ddestroy);
>>          INIT_LIST_HEAD(&fbo->base.lru);
>>          INIT_LIST_HEAD(&fbo->base.swap);
>> @@ -602,7 +602,7 @@ static int ttm_bo_move_to_ghost(struct ttm_buffer_object *bo,
>>   static void ttm_bo_move_pipeline_evict(struct ttm_buffer_object *bo,
>>                                         struct dma_fence *fence)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>          struct ttm_resource_manager *from = ttm_manager_type(bdev, bo->mem.mem_type);
>>
>>          /**
>> @@ -628,7 +628,7 @@ int ttm_bo_move_accel_cleanup(struct ttm_buffer_object *bo,
>>                                bool pipeline,
>>                                struct ttm_resource *new_mem)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>          struct ttm_resource_manager *from = ttm_manager_type(bdev, bo->mem.mem_type);
>>          struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type);
>>          int ret = 0;
>> diff --git a/drivers/gpu/drm/ttm/ttm_bo_vm.c b/drivers/gpu/drm/ttm/ttm_bo_vm.c
>> index 6dc96cf66744..b31b18058965 100644
>> --- a/drivers/gpu/drm/ttm/ttm_bo_vm.c
>> +++ b/drivers/gpu/drm/ttm/ttm_bo_vm.c
>> @@ -95,10 +95,10 @@ static vm_fault_t ttm_bo_vm_fault_idle(struct ttm_buffer_object *bo,
>>   static unsigned long ttm_bo_io_mem_pfn(struct ttm_buffer_object *bo,
>>                                         unsigned long page_offset)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>
>> -       if (bdev->driver->io_mem_pfn)
>> -               return bdev->driver->io_mem_pfn(bo, page_offset);
>> +       if (bdev->funcs->io_mem_pfn)
>> +               return bdev->funcs->io_mem_pfn(bo, page_offset);
>>
>>          return (bo->mem.bus.offset >> PAGE_SHIFT) + page_offset;
>>   }
>> @@ -216,7 +216,7 @@ static vm_fault_t ttm_bo_vm_insert_huge(struct vm_fault *vmf,
>>                          if (page_to_pfn(ttm->pages[page_offset + i]) != pfn + i)
>>                                  goto out_fallback;
>>                  }
>> -       } else if (bo->bdev->driver->io_mem_pfn) {
>> +       } else if (bo->bdev->funcs->io_mem_pfn) {
>>                  for (i = 1; i < fault_page_size; ++i) {
>>                          if (ttm_bo_io_mem_pfn(bo, page_offset + i) != pfn + i)
>>                                  goto out_fallback;
>> @@ -278,7 +278,7 @@ vm_fault_t ttm_bo_vm_fault_reserved(struct vm_fault *vmf,
>>   {
>>          struct vm_area_struct *vma = vmf->vma;
>>          struct ttm_buffer_object *bo = vma->vm_private_data;
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>          unsigned long page_offset;
>>          unsigned long page_last;
>>          unsigned long pfn;
>> @@ -488,8 +488,8 @@ int ttm_bo_vm_access(struct vm_area_struct *vma, unsigned long addr,
>>                  ret = ttm_bo_vm_access_kmap(bo, offset, buf, len, write);
>>                  break;
>>          default:
>> -               if (bo->bdev->driver->access_memory)
>> -                       ret = bo->bdev->driver->access_memory(
>> +               if (bo->bdev->funcs->access_memory)
>> +                       ret = bo->bdev->funcs->access_memory(
>>                                  bo, offset, buf, len, write);
>>                  else
>>                          ret = -EIO;
>> @@ -508,7 +508,7 @@ static const struct vm_operations_struct ttm_bo_vm_ops = {
>>          .access = ttm_bo_vm_access,
>>   };
>>
>> -static struct ttm_buffer_object *ttm_bo_vm_lookup(struct ttm_bo_device *bdev,
>> +static struct ttm_buffer_object *ttm_bo_vm_lookup(struct ttm_device *bdev,
>>                                                    unsigned long offset,
>>                                                    unsigned long pages)
>>   {
>> @@ -555,9 +555,8 @@ static void ttm_bo_mmap_vma_setup(struct ttm_buffer_object *bo, struct vm_area_s
>>   }
>>
>>   int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
>> -               struct ttm_bo_device *bdev)
>> +               struct ttm_device *bdev)
>>   {
>> -       struct ttm_bo_driver *driver;
>>          struct ttm_buffer_object *bo;
>>          int ret;
>>
>> @@ -568,12 +567,11 @@ int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
>>          if (unlikely(!bo))
>>                  return -EINVAL;
>>
>> -       driver = bo->bdev->driver;
>> -       if (unlikely(!driver->verify_access)) {
>> +       if (unlikely(!bo->bdev->funcs->verify_access)) {
>>                  ret = -EPERM;
>>                  goto out_unref;
>>          }
>> -       ret = driver->verify_access(bo, filp);
>> +       ret = bo->bdev->funcs->verify_access(bo, filp);
>>          if (unlikely(ret != 0))
>>                  goto out_unref;
>>
>> diff --git a/drivers/gpu/drm/ttm/ttm_device.c b/drivers/gpu/drm/ttm/ttm_device.c
>> new file mode 100644
>> index 000000000000..ac0903c9e60a
>> --- /dev/null
>> +++ b/drivers/gpu/drm/ttm/ttm_device.c
>> @@ -0,0 +1,195 @@
>> +/* SPDX-License-Identifier: GPL-2.0 OR MIT */
>> +
>> +/*
>> + * Copyright (c) 2006-2009 VMware, Inc., Palo Alto, CA., USA
>> + * Copyright 2020 Advanced Micro Devices, Inc.
>> + *
>> + * Permission is hereby granted, free of charge, to any person obtaining a
>> + * copy of this software and associated documentation files (the "Software"),
>> + * to deal in the Software without restriction, including without limitation
>> + * the rights to use, copy, modify, merge, publish, distribute, sublicense,
>> + * and/or sell copies of the Software, and to permit persons to whom the
>> + * Software is furnished to do so, subject to the following conditions:
>> + *
>> + * The above copyright notice and this permission notice shall be included in
>> + * all copies or substantial portions of the Software.
>> + *
>> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
>> + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
>> + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
>> + * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
>> + * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
>> + * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
>> + * OTHER DEALINGS IN THE SOFTWARE.
>> + *
>> + * Authors: Christian König
>> + */
>> +
>> +#define pr_fmt(fmt) "[TTM DEVICE] " fmt
>> +
>> +#include <drm/ttm/ttm_device.h>
>> +#include <drm/ttm/ttm_memory.h>
>> +#include <drm/ttm/ttm_placement.h>
>> +
>> +#include "ttm_module.h"
>> +
>> +/**
>> + * ttm_global_mutex - protecting the global state
>> + */
>> +DEFINE_MUTEX(ttm_global_mutex);
>> +unsigned ttm_glob_use_count;
>> +struct ttm_global ttm_glob;
>> +EXPORT_SYMBOL(ttm_glob);
>> +
>> +static void ttm_global_release(void)
>> +{
>> +       struct ttm_global *glob = &ttm_glob;
>> +
>> +       mutex_lock(&ttm_global_mutex);
>> +       if (--ttm_glob_use_count > 0)
>> +               goto out;
>> +
>> +       kobject_del(&glob->kobj);
>> +       kobject_put(&glob->kobj);
>> +       ttm_mem_global_release(&ttm_mem_glob);
>> +       __free_page(glob->dummy_read_page);
>> +       memset(glob, 0, sizeof(*glob));
>> +out:
>> +       mutex_unlock(&ttm_global_mutex);
>> +}
>> +
>> +static int ttm_global_init(void)
>> +{
>> +       struct ttm_global *glob = &ttm_glob;
>> +       int ret = 0;
>> +       unsigned i;
>> +
>> +       mutex_lock(&ttm_global_mutex);
>> +       if (++ttm_glob_use_count > 1)
>> +               goto out;
>> +
>> +       ret = ttm_mem_global_init(&ttm_mem_glob);
>> +       if (ret)
>> +               goto out;
>> +
>> +       spin_lock_init(&glob->lru_lock);
>> +       glob->dummy_read_page = alloc_page(__GFP_ZERO | GFP_DMA32);
>> +
>> +       if (unlikely(glob->dummy_read_page == NULL)) {
>> +               ret = -ENOMEM;
>> +               goto out;
>> +       }
>> +
>> +       for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
>> +               INIT_LIST_HEAD(&glob->swap_lru[i]);
>> +       INIT_LIST_HEAD(&glob->device_list);
>> +       atomic_set(&glob->bo_count, 0);
>> +
>> +       debugfs_create_atomic_t("buffer_objects", 0444, ttm_debugfs_root,
>> +                               &glob->bo_count);
>> +out:
>> +       mutex_unlock(&ttm_global_mutex);
>> +       return ret;
>> +}
>> +
>> +static void ttm_init_sysman(struct ttm_device *bdev)
>> +{
>> +       struct ttm_resource_manager *man = &bdev->sysman;
>> +
>> +       /*
>> +        * Initialize the system memory buffer type.
>> +        * Other types need to be driver / IOCTL initialized.
>> +        */
>> +       man->use_tt = true;
>> +
>> +       ttm_resource_manager_init(man, 0);
>> +       ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, man);
>> +       ttm_resource_manager_set_used(man, true);
>> +}
>> +
>> +static void ttm_device_delayed_workqueue(struct work_struct *work)
>> +{
>> +       struct ttm_device *bdev =
>> +               container_of(work, struct ttm_device, wq.work);
>> +
>> +       if (!ttm_bo_delayed_delete(bdev, false))
>> +               schedule_delayed_work(&bdev->wq,
>> +                                     ((HZ / 100) < 1) ? 1 : HZ / 100);
>> +}
>> +
>> +/**
>> + * ttm_device_init
>> + *
>> + * @bdev: A pointer to a struct ttm_device to initialize.
>> + * @funcs: Function table for the device.
>> + * @dev: The core kernel device pointer for DMA mappings and allocations.
>> + * @mapping: The address space to use for this bo.
>> + * @vma_manager: A pointer to a vma manager.
>> + * @use_dma_alloc: If coherent DMA allocation API should be used.
>> + * @use_dma32: If we should use GFP_DMA32 for device memory allocations.
>> + *
>> + * Initializes a struct ttm_device:
>> + * Returns:
>> + * !0: Failure.
>> + */
>> +int ttm_device_init(struct ttm_device *bdev, struct ttm_device_funcs *funcs,
>> +                   struct device *dev, struct address_space *mapping,
>> +                   struct drm_vma_offset_manager *vma_manager,
>> +                   bool use_dma_alloc, bool use_dma32)
>> +{
>> +       struct ttm_global *glob = &ttm_glob;
>> +       int ret;
>> +
>> +       if (WARN_ON(vma_manager == NULL))
>> +               return -EINVAL;
>> +
>> +       ret = ttm_global_init();
>> +       if (ret)
>> +               return ret;
>> +
>> +       bdev->funcs = funcs;
>> +
>> +       ttm_init_sysman(bdev);
>> +       ttm_pool_init(&bdev->pool, dev, use_dma_alloc, use_dma32);
>> +
>> +       bdev->vma_manager = vma_manager;
>> +       INIT_DELAYED_WORK(&bdev->wq, ttm_device_delayed_workqueue);
>> +       INIT_LIST_HEAD(&bdev->ddestroy);
>> +       bdev->dev_mapping = mapping;
>> +       mutex_lock(&ttm_global_mutex);
>> +       list_add_tail(&bdev->device_list, &glob->device_list);
>> +       mutex_unlock(&ttm_global_mutex);
>> +
>> +       return 0;
>> +}
>> +EXPORT_SYMBOL(ttm_device_init);
>> +
>> +void ttm_device_fini(struct ttm_device *bdev)
>> +{
>> +       struct ttm_global *glob = &ttm_glob;
>> +       struct ttm_resource_manager *man;
>> +       unsigned i;
>> +
>> +       man = ttm_manager_type(bdev, TTM_PL_SYSTEM);
>> +       ttm_resource_manager_set_used(man, false);
>> +       ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, NULL);
>> +
>> +       mutex_lock(&ttm_global_mutex);
>> +       list_del(&bdev->device_list);
>> +       mutex_unlock(&ttm_global_mutex);
>> +
>> +       cancel_delayed_work_sync(&bdev->wq);
>> +
>> +       if (ttm_bo_delayed_delete(bdev, true))
>> +               pr_debug("Delayed destroy list was clean\n");
>> +
>> +       spin_lock(&glob->lru_lock);
>> +       for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
>> +               if (list_empty(&man->lru[0]))
>> +                       pr_debug("Swap list %d was clean\n", i);
>> +       spin_unlock(&glob->lru_lock);
>> +
>> +       ttm_pool_fini(&bdev->pool);
>> +       ttm_global_release();
>> +}
>> +EXPORT_SYMBOL(ttm_device_fini);
>> diff --git a/drivers/gpu/drm/ttm/ttm_execbuf_util.c b/drivers/gpu/drm/ttm/ttm_execbuf_util.c
>> index 9fa36ed59429..690ab97d52b7 100644
>> --- a/drivers/gpu/drm/ttm/ttm_execbuf_util.c
>> +++ b/drivers/gpu/drm/ttm/ttm_execbuf_util.c
>> @@ -51,14 +51,14 @@ void ttm_eu_backoff_reservation(struct ww_acquire_ctx *ticket,
>>          if (list_empty(list))
>>                  return;
>>
>> -       spin_lock(&ttm_bo_glob.lru_lock);
>> +       spin_lock(&ttm_glob.lru_lock);
>>          list_for_each_entry(entry, list, head) {
>>                  struct ttm_buffer_object *bo = entry->bo;
>>
>>                  ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
>>                  dma_resv_unlock(bo->base.resv);
>>          }
>> -       spin_unlock(&ttm_bo_glob.lru_lock);
>> +       spin_unlock(&ttm_glob.lru_lock);
>>
>>          if (ticket)
>>                  ww_acquire_fini(ticket);
>> @@ -154,7 +154,7 @@ void ttm_eu_fence_buffer_objects(struct ww_acquire_ctx *ticket,
>>          if (list_empty(list))
>>                  return;
>>
>> -       spin_lock(&ttm_bo_glob.lru_lock);
>> +       spin_lock(&ttm_glob.lru_lock);
>>          list_for_each_entry(entry, list, head) {
>>                  struct ttm_buffer_object *bo = entry->bo;
>>
>> @@ -165,7 +165,7 @@ void ttm_eu_fence_buffer_objects(struct ww_acquire_ctx *ticket,
>>                  ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
>>                  dma_resv_unlock(bo->base.resv);
>>          }
>> -       spin_unlock(&ttm_bo_glob.lru_lock);
>> +       spin_unlock(&ttm_glob.lru_lock);
>>          if (ticket)
>>                  ww_acquire_fini(ticket);
>>   }
>> diff --git a/drivers/gpu/drm/ttm/ttm_range_manager.c b/drivers/gpu/drm/ttm/ttm_range_manager.c
>> index a39305f742da..707e5c152896 100644
>> --- a/drivers/gpu/drm/ttm/ttm_range_manager.c
>> +++ b/drivers/gpu/drm/ttm/ttm_range_manager.c
>> @@ -111,7 +111,7 @@ static void ttm_range_man_free(struct ttm_resource_manager *man,
>>
>>   static const struct ttm_resource_manager_func ttm_range_manager_func;
>>
>> -int ttm_range_man_init(struct ttm_bo_device *bdev,
>> +int ttm_range_man_init(struct ttm_device *bdev,
>>                         unsigned type, bool use_tt,
>>                         unsigned long p_size)
>>   {
>> @@ -138,7 +138,7 @@ int ttm_range_man_init(struct ttm_bo_device *bdev,
>>   }
>>   EXPORT_SYMBOL(ttm_range_man_init);
>>
>> -int ttm_range_man_fini(struct ttm_bo_device *bdev,
>> +int ttm_range_man_fini(struct ttm_device *bdev,
>>                         unsigned type)
>>   {
>>          struct ttm_resource_manager *man = ttm_manager_type(bdev, type);
>> diff --git a/drivers/gpu/drm/ttm/ttm_resource.c b/drivers/gpu/drm/ttm/ttm_resource.c
>> index b60699bf4816..ed1672a9f332 100644
>> --- a/drivers/gpu/drm/ttm/ttm_resource.c
>> +++ b/drivers/gpu/drm/ttm/ttm_resource.c
>> @@ -83,7 +83,7 @@ EXPORT_SYMBOL(ttm_resource_manager_init);
>>    * Evict all the objects out of a memory manager until it is empty.
>>    * Part of memory manager cleanup sequence.
>>    */
>> -int ttm_resource_manager_evict_all(struct ttm_bo_device *bdev,
>> +int ttm_resource_manager_evict_all(struct ttm_device *bdev,
>>                                     struct ttm_resource_manager *man)
>>   {
>>          struct ttm_operation_ctx ctx = {
>> @@ -91,7 +91,7 @@ int ttm_resource_manager_evict_all(struct ttm_bo_device *bdev,
>>                  .no_wait_gpu = false,
>>                  .force_alloc = true
>>          };
>> -       struct ttm_bo_global *glob = &ttm_bo_glob;
>> +       struct ttm_global *glob = &ttm_glob;
>>          struct dma_fence *fence;
>>          int ret;
>>          unsigned i;
>> diff --git a/drivers/gpu/drm/ttm/ttm_tt.c b/drivers/gpu/drm/ttm/ttm_tt.c
>> index 7f75a13163f0..7782d5393c7c 100644
>> --- a/drivers/gpu/drm/ttm/ttm_tt.c
>> +++ b/drivers/gpu/drm/ttm/ttm_tt.c
>> @@ -43,7 +43,7 @@
>>    */
>>   int ttm_tt_create(struct ttm_buffer_object *bo, bool zero_alloc)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>          uint32_t page_flags = 0;
>>
>>          dma_resv_assert_held(bo->base.resv);
>> @@ -66,7 +66,7 @@ int ttm_tt_create(struct ttm_buffer_object *bo, bool zero_alloc)
>>                  return -EINVAL;
>>          }
>>
>> -       bo->ttm = bdev->driver->ttm_tt_create(bo, page_flags);
>> +       bo->ttm = bdev->funcs->ttm_tt_create(bo, page_flags);
>>          if (unlikely(bo->ttm == NULL))
>>                  return -ENOMEM;
>>
>> @@ -108,7 +108,7 @@ static int ttm_sg_tt_alloc_page_directory(struct ttm_tt *ttm)
>>          return 0;
>>   }
>>
>> -void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>> +void ttm_tt_destroy_common(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>>          ttm_tt_unpopulate(bdev, ttm);
>>
>> @@ -119,9 +119,9 @@ void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>>   }
>>   EXPORT_SYMBOL(ttm_tt_destroy_common);
>>
>> -void ttm_tt_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>> +void ttm_tt_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>> -       bdev->driver->ttm_tt_destroy(bdev, ttm);
>> +       bdev->funcs->ttm_tt_destroy(bdev, ttm);
>>   }
>>
>>   static void ttm_tt_init_fields(struct ttm_tt *ttm,
>> @@ -223,7 +223,7 @@ int ttm_tt_swapin(struct ttm_tt *ttm)
>>          return ret;
>>   }
>>
>> -int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>> +int ttm_tt_swapout(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>>          struct address_space *swap_space;
>>          struct file *swap_storage;
>> @@ -271,7 +271,7 @@ int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>>          return ret;
>>   }
>>
>> -static void ttm_tt_add_mapping(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>> +static void ttm_tt_add_mapping(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>>          pgoff_t i;
>>
>> @@ -282,7 +282,7 @@ static void ttm_tt_add_mapping(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>>                  ttm->pages[i]->mapping = bdev->dev_mapping;
>>   }
>>
>> -int ttm_tt_populate(struct ttm_bo_device *bdev,
>> +int ttm_tt_populate(struct ttm_device *bdev,
>>                      struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)
>>   {
>>          int ret;
>> @@ -293,8 +293,8 @@ int ttm_tt_populate(struct ttm_bo_device *bdev,
>>          if (ttm_tt_is_populated(ttm))
>>                  return 0;
>>
>> -       if (bdev->driver->ttm_tt_populate)
>> -               ret = bdev->driver->ttm_tt_populate(bdev, ttm, ctx);
>> +       if (bdev->funcs->ttm_tt_populate)
>> +               ret = bdev->funcs->ttm_tt_populate(bdev, ttm, ctx);
>>          else
>>                  ret = ttm_pool_alloc(&bdev->pool, ttm, ctx);
>>          if (ret)
>> @@ -328,15 +328,15 @@ static void ttm_tt_clear_mapping(struct ttm_tt *ttm)
>>          }
>>   }
>>
>> -void ttm_tt_unpopulate(struct ttm_bo_device *bdev,
>> +void ttm_tt_unpopulate(struct ttm_device *bdev,
>>                         struct ttm_tt *ttm)
>>   {
>>          if (!ttm_tt_is_populated(ttm))
>>                  return;
>>
>>          ttm_tt_clear_mapping(ttm);
>> -       if (bdev->driver->ttm_tt_unpopulate)
>> -               bdev->driver->ttm_tt_unpopulate(bdev, ttm);
>> +       if (bdev->funcs->ttm_tt_unpopulate)
>> +               bdev->funcs->ttm_tt_unpopulate(bdev, ttm);
>>          else
>>                  ttm_pool_free(&bdev->pool, ttm);
>>          ttm->page_flags &= ~TTM_PAGE_FLAG_PRIV_POPULATED;
>> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c b/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c
>> index 118db24eb756..3a438ae4d3f4 100644
>> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c
>> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c
>> @@ -466,13 +466,13 @@ int vmw_bo_cpu_blit(struct ttm_buffer_object *dst,
>>                  dma_resv_assert_held(src->base.resv);
>>
>>          if (!ttm_tt_is_populated(dst->ttm)) {
>> -               ret = dst->bdev->driver->ttm_tt_populate(dst->bdev, dst->ttm, &ctx);
>> +               ret = dst->bdev->funcs->ttm_tt_populate(dst->bdev, dst->ttm, &ctx);
>>                  if (ret)
>>                          return ret;
>>          }
>>
>>          if (!ttm_tt_is_populated(src->ttm)) {
>> -               ret = src->bdev->driver->ttm_tt_populate(src->bdev, src->ttm, &ctx);
>> +               ret = src->bdev->funcs->ttm_tt_populate(src->bdev, src->ttm, &ctx);
>>                  if (ret)
>>                          return ret;
>>          }
>> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c b/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
>> index ab0844b47d4d..6b3bfd8c678a 100644
>> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
>> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
>> @@ -545,7 +545,7 @@ int vmw_bo_init(struct vmw_private *dev_priv,
>>                  void (*bo_free)(struct ttm_buffer_object *bo))
>>   {
>>          struct ttm_operation_ctx ctx = { interruptible, false };
>> -       struct ttm_bo_device *bdev = &dev_priv->bdev;
>> +       struct ttm_device *bdev = &dev_priv->bdev;
>>          size_t acc_size;
>>          int ret;
>>          bool user = (bo_free == &vmw_user_bo_destroy);
>> @@ -1058,7 +1058,7 @@ int vmw_user_bo_reference(struct ttm_object_file *tfile,
>>   void vmw_bo_fence_single(struct ttm_buffer_object *bo,
>>                           struct vmw_fence_obj *fence)
>>   {
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>
>>          struct vmw_private *dev_priv =
>>                  container_of(bdev, struct vmw_private, bdev);
>> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
>> index eb997f4678de..b454d80c273e 100644
>> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
>> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
>> @@ -884,12 +884,12 @@ static int vmw_driver_load(struct vmw_private *dev_priv, u32 pci_id)
>>          drm_vma_offset_manager_init(&dev_priv->vma_manager,
>>                                      DRM_FILE_PAGE_OFFSET_START,
>>                                      DRM_FILE_PAGE_OFFSET_SIZE);
>> -       ret = ttm_bo_device_init(&dev_priv->bdev, &vmw_bo_driver,
>> -                                dev_priv->drm.dev,
>> -                                dev_priv->drm.anon_inode->i_mapping,
>> -                                &dev_priv->vma_manager,
>> -                                dev_priv->map_mode == vmw_dma_alloc_coherent,
>> -                                false);
>> +       ret = ttm_device_init(&dev_priv->bdev, &vmw_bo_driver,
>> +                             dev_priv->drm.dev,
>> +                             dev_priv->drm.anon_inode->i_mapping,
>> +                             &dev_priv->vma_manager,
>> +                             dev_priv->map_mode == vmw_dma_alloc_coherent,
>> +                             false);
>>          if (unlikely(ret != 0)) {
>>                  DRM_ERROR("Failed initializing TTM buffer object driver.\n");
>>                  goto out_no_bdev;
>> @@ -1006,7 +1006,7 @@ static int vmw_driver_load(struct vmw_private *dev_priv, u32 pci_id)
>>                  vmw_gmrid_man_fini(dev_priv, VMW_PL_GMR);
>>          vmw_vram_manager_fini(dev_priv);
>>   out_no_vram:
>> -       (void)ttm_bo_device_release(&dev_priv->bdev);
>> +       ttm_device_fini(&dev_priv->bdev);
>>   out_no_bdev:
>>          vmw_fence_manager_takedown(dev_priv->fman);
>>   out_no_fman:
>> @@ -1053,7 +1053,7 @@ static void vmw_driver_unload(struct drm_device *dev)
>>          if (dev_priv->has_mob)
>>                  vmw_gmrid_man_fini(dev_priv, VMW_PL_MOB);
>>          vmw_vram_manager_fini(dev_priv);
>> -       (void) ttm_bo_device_release(&dev_priv->bdev);
>> +       ttm_device_fini(&dev_priv->bdev);
>>          drm_vma_offset_manager_destroy(&dev_priv->vma_manager);
>>          vmw_release_device_late(dev_priv);
>>          vmw_fence_manager_takedown(dev_priv->fman);
>> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
>> index 336f5086ca26..e65b00f8336d 100644
>> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
>> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
>> @@ -484,7 +484,7 @@ enum vmw_sm_type {
>>
>>   struct vmw_private {
>>          struct drm_device drm;
>> -       struct ttm_bo_device bdev;
>> +       struct ttm_device bdev;
>>
>>          struct vmw_fifo_state fifo;
>>
>> @@ -999,7 +999,7 @@ extern struct ttm_placement vmw_evictable_placement;
>>   extern struct ttm_placement vmw_srf_placement;
>>   extern struct ttm_placement vmw_mob_placement;
>>   extern struct ttm_placement vmw_nonfixed_placement;
>> -extern struct ttm_bo_driver vmw_bo_driver;
>> +extern struct ttm_device_funcs vmw_bo_driver;
>>   extern const struct vmw_sg_table *
>>   vmw_bo_sg_table(struct ttm_buffer_object *bo);
>>   extern int vmw_bo_create_and_populate(struct vmw_private *dev_priv,
>> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c b/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c
>> index c4df51a2a926..c3a724e37104 100644
>> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c
>> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c
>> @@ -856,7 +856,7 @@ void vmw_query_move_notify(struct ttm_buffer_object *bo,
>>                             struct ttm_resource *mem)
>>   {
>>          struct vmw_buffer_object *dx_query_mob;
>> -       struct ttm_bo_device *bdev = bo->bdev;
>> +       struct ttm_device *bdev = bo->bdev;
>>          struct vmw_private *dev_priv;
>>
>>
>> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c b/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c
>> index 6a44567e4ba5..d1bfa59579f1 100644
>> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c
>> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c
>> @@ -483,7 +483,7 @@ const struct vmw_sg_table *vmw_bo_sg_table(struct ttm_buffer_object *bo)
>>   }
>>
>>
>> -static int vmw_ttm_bind(struct ttm_bo_device *bdev,
>> +static int vmw_ttm_bind(struct ttm_device *bdev,
>>                          struct ttm_tt *ttm, struct ttm_resource *bo_mem)
>>   {
>>          struct vmw_ttm_tt *vmw_be =
>> @@ -527,7 +527,7 @@ static int vmw_ttm_bind(struct ttm_bo_device *bdev,
>>          return ret;
>>   }
>>
>> -static void vmw_ttm_unbind(struct ttm_bo_device *bdev,
>> +static void vmw_ttm_unbind(struct ttm_device *bdev,
>>                             struct ttm_tt *ttm)
>>   {
>>          struct vmw_ttm_tt *vmw_be =
>> @@ -553,7 +553,7 @@ static void vmw_ttm_unbind(struct ttm_bo_device *bdev,
>>   }
>>
>>
>> -static void vmw_ttm_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>> +static void vmw_ttm_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>>   {
>>          struct vmw_ttm_tt *vmw_be =
>>                  container_of(ttm, struct vmw_ttm_tt, dma_ttm);
>> @@ -573,7 +573,7 @@ static void vmw_ttm_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>>   }
>>
>>
>> -static int vmw_ttm_populate(struct ttm_bo_device *bdev,
>> +static int vmw_ttm_populate(struct ttm_device *bdev,
>>                              struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)
>>   {
>>          /* TODO: maybe completely drop this ? */
>> @@ -583,7 +583,7 @@ static int vmw_ttm_populate(struct ttm_bo_device *bdev,
>>          return ttm_pool_alloc(&bdev->pool, ttm, ctx);
>>   }
>>
>> -static void vmw_ttm_unpopulate(struct ttm_bo_device *bdev,
>> +static void vmw_ttm_unpopulate(struct ttm_device *bdev,
>>                                 struct ttm_tt *ttm)
>>   {
>>          struct vmw_ttm_tt *vmw_tt = container_of(ttm, struct vmw_ttm_tt,
>> @@ -640,7 +640,7 @@ static int vmw_verify_access(struct ttm_buffer_object *bo, struct file *filp)
>>          return vmw_user_bo_verify_access(bo, tfile);
>>   }
>>
>> -static int vmw_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *mem)
>> +static int vmw_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *mem)
>>   {
>>          struct vmw_private *dev_priv = container_of(bdev, struct vmw_private, bdev);
>>
>> @@ -744,7 +744,7 @@ vmw_delete_mem_notify(struct ttm_buffer_object *bo)
>>          vmw_move_notify(bo, false, NULL);
>>   }
>>
>> -struct ttm_bo_driver vmw_bo_driver = {
>> +struct ttm_device_funcs vmw_bo_driver = {
>>          .ttm_tt_create = &vmw_ttm_tt_create,
>>          .ttm_tt_populate = &vmw_ttm_populate,
>>          .ttm_tt_unpopulate = &vmw_ttm_unpopulate,
>> diff --git a/include/drm/drm_gem_vram_helper.h b/include/drm/drm_gem_vram_helper.h
>> index a4bac02249c2..288055d397d9 100644
>> --- a/include/drm/drm_gem_vram_helper.h
>> +++ b/include/drm/drm_gem_vram_helper.h
>> @@ -172,19 +172,19 @@ struct drm_vram_mm {
>>          uint64_t vram_base;
>>          size_t vram_size;
>>
>> -       struct ttm_bo_device bdev;
>> +       struct ttm_device bdev;
>>   };
>>
>>   /**
>>    * drm_vram_mm_of_bdev() - \
>> -       Returns the container of type &struct ttm_bo_device for field bdev.
>> +       Returns the container of type &struct ttm_device for field bdev.
>>    * @bdev:      the TTM BO device
>>    *
>>    * Returns:
>>    * The containing instance of &struct drm_vram_mm
>>    */
>>   static inline struct drm_vram_mm *drm_vram_mm_of_bdev(
>> -       struct ttm_bo_device *bdev)
>> +       struct ttm_device *bdev)
>>   {
>>          return container_of(bdev, struct drm_vram_mm, bdev);
>>   }
>> diff --git a/include/drm/ttm/ttm_bo_api.h b/include/drm/ttm/ttm_bo_api.h
>> index e17be324d95f..62734db0b421 100644
>> --- a/include/drm/ttm/ttm_bo_api.h
>> +++ b/include/drm/ttm/ttm_bo_api.h
>> @@ -44,9 +44,9 @@
>>
>>   #include "ttm_resource.h"
>>
>> -struct ttm_bo_global;
>> +struct ttm_global;
>>
>> -struct ttm_bo_device;
>> +struct ttm_device;
>>
>>   struct dma_buf_map;
>>
>> @@ -122,7 +122,7 @@ struct ttm_buffer_object {
>>           * Members constant at init.
>>           */
>>
>> -       struct ttm_bo_device *bdev;
>> +       struct ttm_device *bdev;
>>          enum ttm_bo_type type;
>>          void (*destroy) (struct ttm_buffer_object *);
>>          size_t acc_size;
>> @@ -313,7 +313,7 @@ void ttm_bo_put(struct ttm_buffer_object *bo);
>>    * @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
>> + * object. This function must be called with struct ttm_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,
>> @@ -326,7 +326,7 @@ void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
>>    * @bulk: bulk move structure
>>    *
>>    * Bulk move BOs to the LRU tail, only valid to use when driver makes sure that
>> - * BO order never changes. Should be called with ttm_bo_global::lru_lock held.
>> + * BO order never changes. Should be called with ttm_global::lru_lock held.
>>    */
>>   void ttm_bo_bulk_move_lru_tail(struct ttm_lru_bulk_move *bulk);
>>
>> @@ -337,14 +337,14 @@ void ttm_bo_bulk_move_lru_tail(struct ttm_lru_bulk_move *bulk);
>>    * Returns
>>    * True if the workqueue was queued at the time
>>    */
>> -int ttm_bo_lock_delayed_workqueue(struct ttm_bo_device *bdev);
>> +int ttm_bo_lock_delayed_workqueue(struct ttm_device *bdev);
>>
>>   /**
>>    * ttm_bo_unlock_delayed_workqueue
>>    *
>>    * Allows the delayed workqueue to run.
>>    */
>> -void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev, int resched);
>> +void ttm_bo_unlock_delayed_workqueue(struct ttm_device *bdev, int resched);
>>
>>   /**
>>    * ttm_bo_eviction_valuable
>> @@ -357,14 +357,14 @@ void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev, int resched);
>>   bool ttm_bo_eviction_valuable(struct ttm_buffer_object *bo,
>>                                const struct ttm_place *place);
>>
>> -size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
>> +size_t ttm_bo_dma_acc_size(struct ttm_device *bdev,
>>                             unsigned long bo_size,
>>                             unsigned struct_size);
>>
>>   /**
>>    * ttm_bo_init_reserved
>>    *
>> - * @bdev: Pointer to a ttm_bo_device struct.
>> + * @bdev: Pointer to a ttm_device struct.
>>    * @bo: Pointer to a ttm_buffer_object to be initialized.
>>    * @size: Requested size of buffer object.
>>    * @type: Requested type of buffer object.
>> @@ -396,7 +396,7 @@ size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
>>    * -ERESTARTSYS: Interrupted by signal while sleeping waiting for resources.
>>    */
>>
>> -int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>> +int ttm_bo_init_reserved(struct ttm_device *bdev,
>>                           struct ttm_buffer_object *bo,
>>                           size_t size, enum ttm_bo_type type,
>>                           struct ttm_placement *placement,
>> @@ -409,7 +409,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>>   /**
>>    * ttm_bo_init
>>    *
>> - * @bdev: Pointer to a ttm_bo_device struct.
>> + * @bdev: Pointer to a ttm_device struct.
>>    * @bo: Pointer to a ttm_buffer_object to be initialized.
>>    * @size: Requested size of buffer object.
>>    * @type: Requested type of buffer object.
>> @@ -443,7 +443,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>>    * -EINVAL: Invalid placement flags.
>>    * -ERESTARTSYS: Interrupted by signal while sleeping waiting for resources.
>>    */
>> -int ttm_bo_init(struct ttm_bo_device *bdev, struct ttm_buffer_object *bo,
>> +int ttm_bo_init(struct ttm_device *bdev, struct ttm_buffer_object *bo,
>>                  size_t size, enum ttm_bo_type type,
>>                  struct ttm_placement *placement,
>>                  uint32_t page_alignment, bool interrubtible, size_t acc_size,
>> @@ -537,18 +537,18 @@ int ttm_bo_mmap_obj(struct vm_area_struct *vma, struct ttm_buffer_object *bo);
>>    *
>>    * @filp:      filp as input from the mmap method.
>>    * @vma:       vma as input from the mmap method.
>> - * @bdev:      Pointer to the ttm_bo_device with the address space manager.
>> + * @bdev:      Pointer to the ttm_device with the address space manager.
>>    *
>>    * This function is intended to be called by the device mmap method.
>>    * if the device address space is to be backed by the bo manager.
>>    */
>>   int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
>> -               struct ttm_bo_device *bdev);
>> +               struct ttm_device *bdev);
>>
>>   /**
>>    * ttm_bo_io
>>    *
>> - * @bdev:      Pointer to the struct ttm_bo_device.
>> + * @bdev:      Pointer to the struct ttm_device.
>>    * @filp:      Pointer to the struct file attempting to read / write.
>>    * @wbuf:      User-space pointer to address of buffer to write. NULL on read.
>>    * @rbuf:      User-space pointer to address of buffer to read into.
>> @@ -565,7 +565,7 @@ int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
>>    * the function may return -ERESTARTSYS if
>>    * interrupted by a signal.
>>    */
>> -ssize_t ttm_bo_io(struct ttm_bo_device *bdev, struct file *filp,
>> +ssize_t ttm_bo_io(struct ttm_device *bdev, struct file *filp,
>>                    const char __user *wbuf, char __user *rbuf,
>>                    size_t count, loff_t *f_pos, bool write);
>>
>> @@ -617,7 +617,7 @@ static inline void ttm_bo_unpin(struct ttm_buffer_object *bo)
>>          --bo->pin_count;
>>   }
>>
>> -int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>> +int ttm_mem_evict_first(struct ttm_device *bdev,
>>                          struct ttm_resource_manager *man,
>>                          const struct ttm_place *place,
>>                          struct ttm_operation_ctx *ctx,
>> @@ -642,5 +642,6 @@ void ttm_bo_vm_close(struct vm_area_struct *vma);
>>
>>   int ttm_bo_vm_access(struct vm_area_struct *vma, unsigned long addr,
>>                       void *buf, int len, int write);
>> +bool ttm_bo_delayed_delete(struct ttm_device *bdev, bool remove_all);
>>
>>   #endif
>> diff --git a/include/drm/ttm/ttm_bo_driver.h b/include/drm/ttm/ttm_bo_driver.h
>> index 423348414c59..1c9bf993e252 100644
>> --- a/include/drm/ttm/ttm_bo_driver.h
>> +++ b/include/drm/ttm/ttm_bo_driver.h
>> @@ -37,301 +37,14 @@
>>   #include <linux/spinlock.h>
>>   #include <linux/dma-resv.h>
>>
>> +#include <drm/ttm/ttm_device.h>
>> +
>>   #include "ttm_bo_api.h"
>>   #include "ttm_memory.h"
>>   #include "ttm_placement.h"
>>   #include "ttm_tt.h"
>>   #include "ttm_pool.h"
>>
>> -/**
>> - * struct ttm_bo_driver
>> - *
>> - * @create_ttm_backend_entry: Callback to create a struct ttm_backend.
>> - * @evict_flags: Callback to obtain placement flags when a buffer is evicted.
>> - * @move: Callback for a driver to hook in accelerated functions to
>> - * move a buffer.
>> - * If set to NULL, a potentially slow memcpy() move is used.
>> - */
>> -
>> -struct ttm_bo_driver {
>> -       /**
>> -        * ttm_tt_create
>> -        *
>> -        * @bo: The buffer object to create the ttm for.
>> -        * @page_flags: Page flags as identified by TTM_PAGE_FLAG_XX flags.
>> -        *
>> -        * Create a struct ttm_tt to back data with system memory pages.
>> -        * No pages are actually allocated.
>> -        * Returns:
>> -        * NULL: Out of memory.
>> -        */
>> -       struct ttm_tt *(*ttm_tt_create)(struct ttm_buffer_object *bo,
>> -                                       uint32_t page_flags);
>> -
>> -       /**
>> -        * ttm_tt_populate
>> -        *
>> -        * @ttm: The struct ttm_tt to contain the backing pages.
>> -        *
>> -        * Allocate all backing pages
>> -        * Returns:
>> -        * -ENOMEM: Out of memory.
>> -        */
>> -       int (*ttm_tt_populate)(struct ttm_bo_device *bdev,
>> -                              struct ttm_tt *ttm,
>> -                              struct ttm_operation_ctx *ctx);
>> -
>> -       /**
>> -        * ttm_tt_unpopulate
>> -        *
>> -        * @ttm: The struct ttm_tt to contain the backing pages.
>> -        *
>> -        * Free all backing page
>> -        */
>> -       void (*ttm_tt_unpopulate)(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>> -
>> -       /**
>> -        * ttm_tt_destroy
>> -        *
>> -        * @bdev: Pointer to a ttm device
>> -        * @ttm: Pointer to a struct ttm_tt.
>> -        *
>> -        * Destroy the backend. This will be call back from ttm_tt_destroy so
>> -        * don't call ttm_tt_destroy from the callback or infinite loop.
>> -        */
>> -       void (*ttm_tt_destroy)(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>> -
>> -       /**
>> -        * struct ttm_bo_driver member eviction_valuable
>> -        *
>> -        * @bo: the buffer object to be evicted
>> -        * @place: placement we need room for
>> -        *
>> -        * Check with the driver if it is valuable to evict a BO to make room
>> -        * for a certain placement.
>> -        */
>> -       bool (*eviction_valuable)(struct ttm_buffer_object *bo,
>> -                                 const struct ttm_place *place);
>> -       /**
>> -        * struct ttm_bo_driver member evict_flags:
>> -        *
>> -        * @bo: the buffer object to be evicted
>> -        *
>> -        * Return the bo flags for a buffer which is not mapped to the hardware.
>> -        * These will be placed in proposed_flags so that when the move is
>> -        * finished, they'll end up in bo->mem.flags
>> -        * This should not cause multihop evictions, and the core will warn
>> -        * if one is proposed.
>> -        */
>> -
>> -       void (*evict_flags)(struct ttm_buffer_object *bo,
>> -                           struct ttm_placement *placement);
>> -
>> -       /**
>> -        * struct ttm_bo_driver member move:
>> -        *
>> -        * @bo: the buffer to move
>> -        * @evict: whether this motion is evicting the buffer from
>> -        * the graphics address space
>> -        * @ctx: context for this move with parameters
>> -        * @new_mem: the new memory region receiving the buffer
>> -        @ @hop: placement for driver directed intermediate hop
>> -        *
>> -        * Move a buffer between two memory regions.
>> -        * Returns errno -EMULTIHOP if driver requests a hop
>> -        */
>> -       int (*move)(struct ttm_buffer_object *bo, bool evict,
>> -                   struct ttm_operation_ctx *ctx,
>> -                   struct ttm_resource *new_mem,
>> -                   struct ttm_place *hop);
>> -
>> -       /**
>> -        * struct ttm_bo_driver_member verify_access
>> -        *
>> -        * @bo: Pointer to a buffer object.
>> -        * @filp: Pointer to a struct file trying to access the object.
>> -        *
>> -        * Called from the map / write / read methods to verify that the
>> -        * caller is permitted to access the buffer object.
>> -        * This member may be set to NULL, which will refuse this kind of
>> -        * access for all buffer objects.
>> -        * This function should return 0 if access is granted, -EPERM otherwise.
>> -        */
>> -       int (*verify_access)(struct ttm_buffer_object *bo,
>> -                            struct file *filp);
>> -
>> -       /**
>> -        * Hook to notify driver about a resource delete.
>> -        */
>> -       void (*delete_mem_notify)(struct ttm_buffer_object *bo);
>> -
>> -       /**
>> -        * notify the driver that we're about to swap out this bo
>> -        */
>> -       void (*swap_notify)(struct ttm_buffer_object *bo);
>> -
>> -       /**
>> -        * Driver callback on when mapping io memory (for bo_move_memcpy
>> -        * for instance). TTM will take care to call io_mem_free whenever
>> -        * the mapping is not use anymore. io_mem_reserve & io_mem_free
>> -        * are balanced.
>> -        */
>> -       int (*io_mem_reserve)(struct ttm_bo_device *bdev,
>> -                             struct ttm_resource *mem);
>> -       void (*io_mem_free)(struct ttm_bo_device *bdev,
>> -                           struct ttm_resource *mem);
>> -
>> -       /**
>> -        * Return the pfn for a given page_offset inside the BO.
>> -        *
>> -        * @bo: the BO to look up the pfn for
>> -        * @page_offset: the offset to look up
>> -        */
>> -       unsigned long (*io_mem_pfn)(struct ttm_buffer_object *bo,
>> -                                   unsigned long page_offset);
>> -
>> -       /**
>> -        * Read/write memory buffers for ptrace access
>> -        *
>> -        * @bo: the BO to access
>> -        * @offset: the offset from the start of the BO
>> -        * @buf: pointer to source/destination buffer
>> -        * @len: number of bytes to copy
>> -        * @write: whether to read (0) from or write (non-0) to BO
>> -        *
>> -        * If successful, this function should return the number of
>> -        * bytes copied, -EIO otherwise. If the number of bytes
>> -        * returned is < len, the function may be called again with
>> -        * the remainder of the buffer to copy.
>> -        */
>> -       int (*access_memory)(struct ttm_buffer_object *bo, unsigned long offset,
>> -                            void *buf, int len, int write);
>> -
>> -       /**
>> -        * struct ttm_bo_driver member del_from_lru_notify
>> -        *
>> -        * @bo: the buffer object deleted from lru
>> -        *
>> -        * notify driver that a BO was deleted from LRU.
>> -        */
>> -       void (*del_from_lru_notify)(struct ttm_buffer_object *bo);
>> -
>> -       /**
>> -        * Notify the driver that we're about to release a BO
>> -        *
>> -        * @bo: BO that is about to be released
>> -        *
>> -        * Gives the driver a chance to do any cleanup, including
>> -        * adding fences that may force a delayed delete
>> -        */
>> -       void (*release_notify)(struct ttm_buffer_object *bo);
>> -};
>> -
>> -/**
>> - * struct ttm_bo_global - Buffer object driver global data.
>> - *
>> - * @dummy_read_page: Pointer to a dummy page used for mapping requests
>> - * of unpopulated pages.
>> - * @shrink: A shrink callback object used for buffer object swap.
>> - * @device_list_mutex: Mutex protecting the device list.
>> - * This mutex is held while traversing the device list for pm options.
>> - * @lru_lock: Spinlock protecting the bo subsystem lru lists.
>> - * @device_list: List of buffer object devices.
>> - * @swap_lru: Lru list of buffer objects used for swapping.
>> - */
>> -
>> -extern struct ttm_bo_global {
>> -
>> -       /**
>> -        * Constant after init.
>> -        */
>> -
>> -       struct kobject kobj;
>> -       struct page *dummy_read_page;
>> -       spinlock_t lru_lock;
>> -
>> -       /**
>> -        * Protected by ttm_global_mutex.
>> -        */
>> -       struct list_head device_list;
>> -
>> -       /**
>> -        * Protected by the lru_lock.
>> -        */
>> -       struct list_head swap_lru[TTM_MAX_BO_PRIORITY];
>> -
>> -       /**
>> -        * Internal protection.
>> -        */
>> -       atomic_t bo_count;
>> -} ttm_bo_glob;
>> -
>> -
>> -#define TTM_NUM_MEM_TYPES 8
>> -
>> -/**
>> - * struct ttm_bo_device - Buffer object driver device-specific data.
>> - *
>> - * @driver: Pointer to a struct ttm_bo_driver struct setup by the driver.
>> - * @man: An array of resource_managers.
>> - * @vma_manager: Address space manager (pointer)
>> - * lru_lock: Spinlock that protects the buffer+device lru lists and
>> - * ddestroy lists.
>> - * @dev_mapping: A pointer to the struct address_space representing the
>> - * device address space.
>> - * @wq: Work queue structure for the delayed delete workqueue.
>> - *
>> - */
>> -
>> -struct ttm_bo_device {
>> -
>> -       /*
>> -        * Constant after bo device init / atomic.
>> -        */
>> -       struct list_head device_list;
>> -       struct ttm_bo_driver *driver;
>> -       /*
>> -        * access via ttm_manager_type.
>> -        */
>> -       struct ttm_resource_manager sysman;
>> -       struct ttm_resource_manager *man_drv[TTM_NUM_MEM_TYPES];
>> -       /*
>> -        * Protected by internal locks.
>> -        */
>> -       struct drm_vma_offset_manager *vma_manager;
>> -       struct ttm_pool pool;
>> -
>> -       /*
>> -        * Protected by the global:lru lock.
>> -        */
>> -       struct list_head ddestroy;
>> -
>> -       /*
>> -        * Protected by load / firstopen / lastclose /unload sync.
>> -        */
>> -
>> -       struct address_space *dev_mapping;
>> -
>> -       /*
>> -        * Internal protection.
>> -        */
>> -
>> -       struct delayed_work wq;
>> -};
>> -
>> -static inline struct ttm_resource_manager *ttm_manager_type(struct ttm_bo_device *bdev,
>> -                                                           int mem_type)
>> -{
>> -       return bdev->man_drv[mem_type];
>> -}
>> -
>> -static inline void ttm_set_driver_manager(struct ttm_bo_device *bdev,
>> -                                         int type,
>> -                                         struct ttm_resource_manager *manager)
>> -{
>> -       bdev->man_drv[type] = manager;
>> -}
>> -
>>   /**
>>    * struct ttm_lru_bulk_move_pos
>>    *
>> @@ -388,31 +101,6 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
>>                       struct ttm_resource *mem,
>>                       struct ttm_operation_ctx *ctx);
>>
>> -int ttm_bo_device_release(struct ttm_bo_device *bdev);
>> -
>> -/**
>> - * ttm_bo_device_init
>> - *
>> - * @bdev: A pointer to a struct ttm_bo_device to initialize.
>> - * @glob: A pointer to an initialized struct ttm_bo_global.
>> - * @driver: A pointer to a struct ttm_bo_driver set up by the caller.
>> - * @dev: The core kernel device pointer for DMA mappings and allocations.
>> - * @mapping: The address space to use for this bo.
>> - * @vma_manager: A pointer to a vma manager.
>> - * @use_dma_alloc: If coherent DMA allocation API should be used.
>> - * @use_dma32: If we should use GFP_DMA32 for device memory allocations.
>> - *
>> - * Initializes a struct ttm_bo_device:
>> - * Returns:
>> - * !0: Failure.
>> - */
>> -int ttm_bo_device_init(struct ttm_bo_device *bdev,
>> -                      struct ttm_bo_driver *driver,
>> -                      struct device *dev,
>> -                      struct address_space *mapping,
>> -                      struct drm_vma_offset_manager *vma_manager,
>> -                      bool use_dma_alloc, bool use_dma32);
>> -
>>   /**
>>    * ttm_bo_unmap_virtual
>>    *
>> @@ -494,9 +182,9 @@ static inline int ttm_bo_reserve_slowpath(struct ttm_buffer_object *bo,
>>   static inline void
>>   ttm_bo_move_to_lru_tail_unlocked(struct ttm_buffer_object *bo)
>>   {
>> -       spin_lock(&ttm_bo_glob.lru_lock);
>> +       spin_lock(&ttm_glob.lru_lock);
>>          ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
>> -       spin_unlock(&ttm_bo_glob.lru_lock);
>> +       spin_unlock(&ttm_glob.lru_lock);
>>   }
>>
>>   static inline void ttm_bo_assign_mem(struct ttm_buffer_object *bo,
>> @@ -538,9 +226,9 @@ static inline void ttm_bo_unreserve(struct ttm_buffer_object *bo)
>>   /*
>>    * ttm_bo_util.c
>>    */
>> -int ttm_mem_io_reserve(struct ttm_bo_device *bdev,
>> +int ttm_mem_io_reserve(struct ttm_device *bdev,
>>                         struct ttm_resource *mem);
>> -void ttm_mem_io_free(struct ttm_bo_device *bdev,
>> +void ttm_mem_io_free(struct ttm_device *bdev,
>>                       struct ttm_resource *mem);
>>
>>   /**
>> @@ -631,7 +319,7 @@ void ttm_bo_tt_destroy(struct ttm_buffer_object *bo);
>>    * Initialise a generic range manager for the selected memory type.
>>    * The range manager is installed for this device in the type slot.
>>    */
>> -int ttm_range_man_init(struct ttm_bo_device *bdev,
>> +int ttm_range_man_init(struct ttm_device *bdev,
>>                         unsigned type, bool use_tt,
>>                         unsigned long p_size);
>>
>> @@ -643,7 +331,7 @@ int ttm_range_man_init(struct ttm_bo_device *bdev,
>>    *
>>    * Remove the generic range manager from a slot and tear it down.
>>    */
>> -int ttm_range_man_fini(struct ttm_bo_device *bdev,
>> +int ttm_range_man_fini(struct ttm_device *bdev,
>>                         unsigned type);
>>
>>   #endif
>> diff --git a/include/drm/ttm/ttm_device.h b/include/drm/ttm/ttm_device.h
>> new file mode 100644
>> index 000000000000..7bc8bb797161
>> --- /dev/null
>> +++ b/include/drm/ttm/ttm_device.h
>> @@ -0,0 +1,319 @@
>> +/*
>> + * Copyright 2020 Advanced Micro Devices, Inc.
>> + *
>> + * Permission is hereby granted, free of charge, to any person obtaining a
>> + * copy of this software and associated documentation files (the "Software"),
>> + * to deal in the Software without restriction, including without limitation
>> + * the rights to use, copy, modify, merge, publish, distribute, sublicense,
>> + * and/or sell copies of the Software, and to permit persons to whom the
>> + * Software is furnished to do so, subject to the following conditions:
>> + *
>> + * The above copyright notice and this permission notice shall be included in
>> + * all copies or substantial portions of the Software.
>> + *
>> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
>> + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
>> + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
>> + * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
>> + * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
>> + * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
>> + * OTHER DEALINGS IN THE SOFTWARE.
>> + *
>> + * Authors: Christian König
>> + */
>> +
>> +#ifndef _TTM_DEVICE_H_
>> +#define _TTM_DEVICE_H_
>> +
>> +#include <linux/types.h>
>> +#include <linux/workqueue.h>
>> +#include <drm/ttm/ttm_resource.h>
>> +#include <drm/ttm/ttm_pool.h>
>> +
>> +#define TTM_NUM_MEM_TYPES 8
>> +
>> +struct ttm_device;
>> +struct ttm_placement;
>> +struct ttm_buffer_object;
>> +struct ttm_operation_ctx;
>> +
>> +/**
>> + * struct ttm_global - Buffer object driver global data.
>> + *
>> + * @dummy_read_page: Pointer to a dummy page used for mapping requests
>> + * of unpopulated pages.
>> + * @shrink: A shrink callback object used for buffer object swap.
>> + * @device_list_mutex: Mutex protecting the device list.
>> + * This mutex is held while traversing the device list for pm options.
>> + * @lru_lock: Spinlock protecting the bo subsystem lru lists.
>> + * @device_list: List of buffer object devices.
>> + * @swap_lru: Lru list of buffer objects used for swapping.
>> + */
>> +extern struct ttm_global {
>> +
>> +       /**
>> +        * Constant after init.
>> +        */
>> +
>> +       struct kobject kobj;
>> +       struct page *dummy_read_page;
>> +       spinlock_t lru_lock;
>> +
>> +       /**
>> +        * Protected by ttm_global_mutex.
>> +        */
>> +       struct list_head device_list;
>> +
>> +       /**
>> +        * Protected by the lru_lock.
>> +        */
>> +       struct list_head swap_lru[TTM_MAX_BO_PRIORITY];
>> +
>> +       /**
>> +        * Internal protection.
>> +        */
>> +       atomic_t bo_count;
>> +} ttm_glob;
>> +
>> +struct ttm_device_funcs {
>> +       /**
>> +        * ttm_tt_create
>> +        *
>> +        * @bo: The buffer object to create the ttm for.
>> +        * @page_flags: Page flags as identified by TTM_PAGE_FLAG_XX flags.
>> +        *
>> +        * Create a struct ttm_tt to back data with system memory pages.
>> +        * No pages are actually allocated.
>> +        * Returns:
>> +        * NULL: Out of memory.
>> +        */
>> +       struct ttm_tt *(*ttm_tt_create)(struct ttm_buffer_object *bo,
>> +                                       uint32_t page_flags);
>> +
>> +       /**
>> +        * ttm_tt_populate
>> +        *
>> +        * @ttm: The struct ttm_tt to contain the backing pages.
>> +        *
>> +        * Allocate all backing pages
>> +        * Returns:
>> +        * -ENOMEM: Out of memory.
>> +        */
>> +       int (*ttm_tt_populate)(struct ttm_device *bdev,
>> +                              struct ttm_tt *ttm,
>> +                              struct ttm_operation_ctx *ctx);
>> +
>> +       /**
>> +        * ttm_tt_unpopulate
>> +        *
>> +        * @ttm: The struct ttm_tt to contain the backing pages.
>> +        *
>> +        * Free all backing page
>> +        */
>> +       void (*ttm_tt_unpopulate)(struct ttm_device *bdev,
>> +                                 struct ttm_tt *ttm);
>> +
>> +       /**
>> +        * ttm_tt_destroy
>> +        *
>> +        * @bdev: Pointer to a ttm device
>> +        * @ttm: Pointer to a struct ttm_tt.
>> +        *
>> +        * Destroy the backend. This will be call back from ttm_tt_destroy so
>> +        * don't call ttm_tt_destroy from the callback or infinite loop.
>> +        */
>> +       void (*ttm_tt_destroy)(struct ttm_device *bdev, struct ttm_tt *ttm);
>> +
>> +       /**
>> +        * struct ttm_bo_driver member eviction_valuable
>> +        *
>> +        * @bo: the buffer object to be evicted
>> +        * @place: placement we need room for
>> +        *
>> +        * Check with the driver if it is valuable to evict a BO to make room
>> +        * for a certain placement.
>> +        */
>> +       bool (*eviction_valuable)(struct ttm_buffer_object *bo,
>> +                                 const struct ttm_place *place);
>> +       /**
>> +        * struct ttm_bo_driver member evict_flags:
>> +        *
>> +        * @bo: the buffer object to be evicted
>> +        *
>> +        * Return the bo flags for a buffer which is not mapped to the hardware.
>> +        * These will be placed in proposed_flags so that when the move is
>> +        * finished, they'll end up in bo->mem.flags
>> +        * This should not cause multihop evictions, and the core will warn
>> +        * if one is proposed.
>> +        */
>> +
>> +       void (*evict_flags)(struct ttm_buffer_object *bo,
>> +                           struct ttm_placement *placement);
>> +
>> +       /**
>> +        * struct ttm_bo_driver member move:
>> +        *
>> +        * @bo: the buffer to move
>> +        * @evict: whether this motion is evicting the buffer from
>> +        * the graphics address space
>> +        * @ctx: context for this move with parameters
>> +        * @new_mem: the new memory region receiving the buffer
>> +        @ @hop: placement for driver directed intermediate hop
>> +        *
>> +        * Move a buffer between two memory regions.
>> +        * Returns errno -EMULTIHOP if driver requests a hop
>> +        */
>> +       int (*move)(struct ttm_buffer_object *bo, bool evict,
>> +                   struct ttm_operation_ctx *ctx,
>> +                   struct ttm_resource *new_mem,
>> +                   struct ttm_place *hop);
>> +
>> +       /**
>> +        * struct ttm_bo_driver_member verify_access
>> +        *
>> +        * @bo: Pointer to a buffer object.
>> +        * @filp: Pointer to a struct file trying to access the object.
>> +        *
>> +        * Called from the map / write / read methods to verify that the
>> +        * caller is permitted to access the buffer object.
>> +        * This member may be set to NULL, which will refuse this kind of
>> +        * access for all buffer objects.
>> +        * This function should return 0 if access is granted, -EPERM otherwise.
>> +        */
>> +       int (*verify_access)(struct ttm_buffer_object *bo,
>> +                            struct file *filp);
>> +
>> +       /**
>> +        * Hook to notify driver about a resource delete.
>> +        */
>> +       void (*delete_mem_notify)(struct ttm_buffer_object *bo);
>> +
>> +       /**
>> +        * notify the driver that we're about to swap out this bo
>> +        */
>> +       void (*swap_notify)(struct ttm_buffer_object *bo);
>> +
>> +       /**
>> +        * Driver callback on when mapping io memory (for bo_move_memcpy
>> +        * for instance). TTM will take care to call io_mem_free whenever
>> +        * the mapping is not use anymore. io_mem_reserve & io_mem_free
>> +        * are balanced.
>> +        */
>> +       int (*io_mem_reserve)(struct ttm_device *bdev,
>> +                             struct ttm_resource *mem);
>> +       void (*io_mem_free)(struct ttm_device *bdev,
>> +                           struct ttm_resource *mem);
>> +
>> +       /**
>> +        * Return the pfn for a given page_offset inside the BO.
>> +        *
>> +        * @bo: the BO to look up the pfn for
>> +        * @page_offset: the offset to look up
>> +        */
>> +       unsigned long (*io_mem_pfn)(struct ttm_buffer_object *bo,
>> +                                   unsigned long page_offset);
>> +
>> +       /**
>> +        * Read/write memory buffers for ptrace access
>> +        *
>> +        * @bo: the BO to access
>> +        * @offset: the offset from the start of the BO
>> +        * @buf: pointer to source/destination buffer
>> +        * @len: number of bytes to copy
>> +        * @write: whether to read (0) from or write (non-0) to BO
>> +        *
>> +        * If successful, this function should return the number of
>> +        * bytes copied, -EIO otherwise. If the number of bytes
>> +        * returned is < len, the function may be called again with
>> +        * the remainder of the buffer to copy.
>> +        */
>> +       int (*access_memory)(struct ttm_buffer_object *bo, unsigned long offset,
>> +                            void *buf, int len, int write);
>> +
>> +       /**
>> +        * struct ttm_bo_driver member del_from_lru_notify
>> +        *
>> +        * @bo: the buffer object deleted from lru
>> +        *
>> +        * notify driver that a BO was deleted from LRU.
>> +        */
>> +       void (*del_from_lru_notify)(struct ttm_buffer_object *bo);
>> +
>> +       /**
>> +        * Notify the driver that we're about to release a BO
>> +        *
>> +        * @bo: BO that is about to be released
>> +        *
>> +        * Gives the driver a chance to do any cleanup, including
>> +        * adding fences that may force a delayed delete
>> +        */
>> +       void (*release_notify)(struct ttm_buffer_object *bo);
>> +};
>> +
>> +/**
>> + * struct ttm_device - Buffer object driver device-specific data.
>> + *
>> + * @device_list: Our entry in the global device list.
>> + * @funcs: Function table for the device.
>> + * @sysman: Resource manager for the system domain.
>> + * @man_drv: An array of resource_managers.
>> + * @vma_manager: Address space manager.
>> + * @pool: page pool for the device.
>> + * @dev_mapping: A pointer to the struct address_space representing the
>> + * device address space.
>> + * @wq: Work queue structure for the delayed delete workqueue.
>> + */
>> +struct ttm_device {
>> +       /*
>> +        * Constant after bo device init
>> +        */
>> +       struct list_head device_list;
>> +       struct ttm_device_funcs *funcs;
>> +
>> +       /*
>> +        * Access via ttm_manager_type.
>> +        */
>> +       struct ttm_resource_manager sysman;
>> +       struct ttm_resource_manager *man_drv[TTM_NUM_MEM_TYPES];
>> +
>> +       /*
>> +        * Protected by internal locks.
>> +        */
>> +       struct drm_vma_offset_manager *vma_manager;
>> +       struct ttm_pool pool;
>> +
>> +       /*
>> +        * Protected by the global:lru lock.
>> +        */
>> +       struct list_head ddestroy;
>> +
>> +       /*
>> +        * Protected by load / firstopen / lastclose /unload sync.
>> +        */
>> +       struct address_space *dev_mapping;
>> +
>> +       /*
>> +        * Internal protection.
>> +        */
>> +       struct delayed_work wq;
>> +};
>> +
>> +static inline struct ttm_resource_manager *
>> +ttm_manager_type(struct ttm_device *bdev, int mem_type)
>> +{
>> +       return bdev->man_drv[mem_type];
>> +}
>> +
>> +static inline void ttm_set_driver_manager(struct ttm_device *bdev, int type,
>> +                                         struct ttm_resource_manager *manager)
>> +{
>> +       bdev->man_drv[type] = manager;
>> +}
>> +
>> +int ttm_device_init(struct ttm_device *bdev, struct ttm_device_funcs *funcs,
>> +                   struct device *dev, struct address_space *mapping,
>> +                   struct drm_vma_offset_manager *vma_manager,
>> +                   bool use_dma_alloc, bool use_dma32);
>> +void ttm_device_fini(struct ttm_device *bdev);
>> +
>> +#endif
>> diff --git a/include/drm/ttm/ttm_resource.h b/include/drm/ttm/ttm_resource.h
>> index da0ed7e8c915..6164ccf4f308 100644
>> --- a/include/drm/ttm/ttm_resource.h
>> +++ b/include/drm/ttm/ttm_resource.h
>> @@ -33,7 +33,7 @@
>>
>>   #define TTM_MAX_BO_PRIORITY    4U
>>
>> -struct ttm_bo_device;
>> +struct ttm_device;
>>   struct ttm_resource_manager;
>>   struct ttm_resource;
>>   struct ttm_place;
>> @@ -233,7 +233,7 @@ void ttm_resource_free(struct ttm_buffer_object *bo, struct ttm_resource *res);
>>   void ttm_resource_manager_init(struct ttm_resource_manager *man,
>>                                 unsigned long p_size);
>>
>> -int ttm_resource_manager_evict_all(struct ttm_bo_device *bdev,
>> +int ttm_resource_manager_evict_all(struct ttm_device *bdev,
>>                                     struct ttm_resource_manager *man);
>>
>>   void ttm_resource_manager_debug(struct ttm_resource_manager *man,
>> diff --git a/include/drm/ttm/ttm_tt.h b/include/drm/ttm/ttm_tt.h
>> index 6c8eb9a4de81..0020a0588985 100644
>> --- a/include/drm/ttm/ttm_tt.h
>> +++ b/include/drm/ttm/ttm_tt.h
>> @@ -118,14 +118,14 @@ void ttm_tt_fini(struct ttm_tt *ttm);
>>    *
>>    * Unbind, unpopulate and destroy common struct ttm_tt.
>>    */
>> -void ttm_tt_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>> +void ttm_tt_destroy(struct ttm_device *bdev, struct ttm_tt *ttm);
>>
>>   /**
>>    * ttm_tt_destroy_common:
>>    *
>>    * Called from driver to destroy common path.
>>    */
>> -void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>> +void ttm_tt_destroy_common(struct ttm_device *bdev, struct ttm_tt *ttm);
>>
>>   /**
>>    * ttm_tt_swapin:
>> @@ -135,7 +135,7 @@ void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>>    * Swap in a previously swap out ttm_tt.
>>    */
>>   int ttm_tt_swapin(struct ttm_tt *ttm);
>> -int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>> +int ttm_tt_swapout(struct ttm_device *bdev, struct ttm_tt *ttm);
>>
>>   /**
>>    * ttm_tt_populate - allocate pages for a ttm
>> @@ -144,7 +144,7 @@ int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>>    *
>>    * Calls the driver method to allocate pages for a ttm
>>    */
>> -int ttm_tt_populate(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_operation_ctx *ctx);
>> +int ttm_tt_populate(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_operation_ctx *ctx);
>>
>>   /**
>>    * ttm_tt_unpopulate - free pages from a ttm
>> @@ -153,7 +153,7 @@ int ttm_tt_populate(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_o
>>    *
>>    * Calls the driver method to free all pages from a ttm
>>    */
>> -void ttm_tt_unpopulate(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>> +void ttm_tt_unpopulate(struct ttm_device *bdev, struct ttm_tt *ttm);
>>
>>   #if IS_ENABLED(CONFIG_AGP)
>>   #include <linux/agp_backend.h>
>> --
>> 2.25.1
>>
>

_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH] drm/ttm: device naming cleanup
  2021-01-21 11:58 [PATCH] drm/ttm: device naming cleanup Christian König
  2021-01-21 13:39 ` Daniel Vetter
@ 2021-01-22  8:27 ` Huang Rui
  1 sibling, 0 replies; 4+ messages in thread
From: Huang Rui @ 2021-01-22  8:27 UTC (permalink / raw)
  To: Christian König; +Cc: dri-devel

On Thu, Jan 21, 2021 at 07:58:18PM +0800, Christian König wrote:
> Rename ttm_bo_device to ttm_device.
> Rename ttm_bo_driver to ttm_device_funcs.
> Rename ttm_bo_global to ttm_global.
> 
> Move global and device related functions to ttm_device.[ch].
> 
> No functional change.
> 
> Signed-off-by: Christian König <christian.koenig@amd.com>

Acked-by: Huang Rui <ray.huang@amd.com>

> ---
>  drivers/gpu/drm/amd/amdgpu/amdgpu.h           |   2 +-
>  .../gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c  |   6 +-
>  drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c      |   2 +-
>  drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c       |  26 +-
>  drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h       |   2 +-
>  drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c        |   8 +-
>  drivers/gpu/drm/drm_gem_vram_helper.c         |  14 +-
>  drivers/gpu/drm/nouveau/nouveau_bo.c          |  20 +-
>  drivers/gpu/drm/nouveau/nouveau_bo.h          |   2 +-
>  drivers/gpu/drm/nouveau/nouveau_drv.h         |   2 +-
>  drivers/gpu/drm/nouveau/nouveau_sgdma.c       |   6 +-
>  drivers/gpu/drm/nouveau/nouveau_ttm.c         |  10 +-
>  drivers/gpu/drm/nouveau/nouveau_ttm.h         |   8 +-
>  drivers/gpu/drm/qxl/qxl_drv.h                 |   4 +-
>  drivers/gpu/drm/qxl/qxl_release.c             |   6 +-
>  drivers/gpu/drm/qxl/qxl_ttm.c                 |  19 +-
>  drivers/gpu/drm/radeon/radeon.h               |   6 +-
>  drivers/gpu/drm/radeon/radeon_object.c        |   2 +-
>  drivers/gpu/drm/radeon/radeon_ttm.c           |  38 +-
>  drivers/gpu/drm/ttm/Makefile                  |   2 +-
>  drivers/gpu/drm/ttm/ttm_agp_backend.c         |   2 +-
>  drivers/gpu/drm/ttm/ttm_bo.c                  | 256 +++-----------
>  drivers/gpu/drm/ttm/ttm_bo_util.c             |  24 +-
>  drivers/gpu/drm/ttm/ttm_bo_vm.c               |  24 +-
>  drivers/gpu/drm/ttm/ttm_device.c              | 195 +++++++++++
>  drivers/gpu/drm/ttm/ttm_execbuf_util.c        |   8 +-
>  drivers/gpu/drm/ttm/ttm_range_manager.c       |   4 +-
>  drivers/gpu/drm/ttm/ttm_resource.c            |   4 +-
>  drivers/gpu/drm/ttm/ttm_tt.c                  |  26 +-
>  drivers/gpu/drm/vmwgfx/vmwgfx_blit.c          |   4 +-
>  drivers/gpu/drm/vmwgfx/vmwgfx_bo.c            |   4 +-
>  drivers/gpu/drm/vmwgfx/vmwgfx_drv.c           |  16 +-
>  drivers/gpu/drm/vmwgfx/vmwgfx_drv.h           |   4 +-
>  drivers/gpu/drm/vmwgfx/vmwgfx_resource.c      |   2 +-
>  drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c    |  14 +-
>  include/drm/drm_gem_vram_helper.h             |   6 +-
>  include/drm/ttm/ttm_bo_api.h                  |  35 +-
>  include/drm/ttm/ttm_bo_driver.h               | 328 +-----------------
>  include/drm/ttm/ttm_device.h                  | 319 +++++++++++++++++
>  include/drm/ttm/ttm_resource.h                |   4 +-
>  include/drm/ttm/ttm_tt.h                      |  10 +-
>  41 files changed, 759 insertions(+), 715 deletions(-)
>  create mode 100644 drivers/gpu/drm/ttm/ttm_device.c
>  create mode 100644 include/drm/ttm/ttm_device.h
> 
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu.h b/drivers/gpu/drm/amd/amdgpu/amdgpu.h
> index f77443cd9c17..ab4ac3b2651e 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu.h
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu.h
> @@ -1053,7 +1053,7 @@ static inline struct drm_device *adev_to_drm(struct amdgpu_device *adev)
>  	return &adev->ddev;
>  }
>  
> -static inline struct amdgpu_device *amdgpu_ttm_adev(struct ttm_bo_device *bdev)
> +static inline struct amdgpu_device *amdgpu_ttm_adev(struct ttm_device *bdev)
>  {
>  	return container_of(bdev, struct amdgpu_device, mman.bdev);
>  }
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c
> index 3107b9575929..5af464933976 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_fence.c
> @@ -40,13 +40,13 @@ static atomic_t fence_seq = ATOMIC_INIT(0);
>   * All the BOs in a process share an eviction fence. When process X wants
>   * to map VRAM memory but TTM can't find enough space, TTM will attempt to
>   * evict BOs from its LRU list. TTM checks if the BO is valuable to evict
> - * by calling ttm_bo_driver->eviction_valuable().
> + * by calling ttm_device_funcs->eviction_valuable().
>   *
> - * ttm_bo_driver->eviction_valuable() - will return false if the BO belongs
> + * ttm_device_funcs->eviction_valuable() - will return false if the BO belongs
>   *  to process X. Otherwise, it will return true to indicate BO can be
>   *  evicted by TTM.
>   *
> - * If ttm_bo_driver->eviction_valuable returns true, then TTM will continue
> + * If ttm_device_funcs->eviction_valuable returns true, then TTM will continue
>   * the evcition process for that BO by calling ttm_bo_evict --> amdgpu_bo_move
>   * --> amdgpu_copy_buffer(). This sets up job in GPU scheduler.
>   *
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c
> index 0db933026722..fde2d899b2c4 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gart.c
> @@ -71,7 +71,7 @@
>   */
>  static int amdgpu_gart_dummy_page_init(struct amdgpu_device *adev)
>  {
> -	struct page *dummy_page = ttm_bo_glob.dummy_read_page;
> +	struct page *dummy_page = ttm_glob.dummy_read_page;
>  
>  	if (adev->dummy_page_addr)
>  		return 0;
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
> index 9fd2157b133a..29cfb0809634 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
> @@ -61,10 +61,10 @@
>  
>  #define AMDGPU_TTM_VRAM_MAX_DW_READ	(size_t)128
>  
> -static int amdgpu_ttm_backend_bind(struct ttm_bo_device *bdev,
> +static int amdgpu_ttm_backend_bind(struct ttm_device *bdev,
>  				   struct ttm_tt *ttm,
>  				   struct ttm_resource *bo_mem);
> -static void amdgpu_ttm_backend_unbind(struct ttm_bo_device *bdev,
> +static void amdgpu_ttm_backend_unbind(struct ttm_device *bdev,
>  				      struct ttm_tt *ttm);
>  
>  static int amdgpu_ttm_init_on_chip(struct amdgpu_device *adev,
> @@ -646,7 +646,7 @@ static int amdgpu_bo_move(struct ttm_buffer_object *bo, bool evict,
>   *
>   * Called by ttm_mem_io_reserve() ultimately via ttm_bo_vm_fault()
>   */
> -static int amdgpu_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *mem)
> +static int amdgpu_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *mem)
>  {
>  	struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
>  	struct drm_mm_node *mm_node = mem->mm_node;
> @@ -893,7 +893,7 @@ void amdgpu_ttm_tt_set_user_pages(struct ttm_tt *ttm, struct page **pages)
>   *
>   * Called by amdgpu_ttm_backend_bind()
>   **/
> -static int amdgpu_ttm_tt_pin_userptr(struct ttm_bo_device *bdev,
> +static int amdgpu_ttm_tt_pin_userptr(struct ttm_device *bdev,
>  				     struct ttm_tt *ttm)
>  {
>  	struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
> @@ -931,7 +931,7 @@ static int amdgpu_ttm_tt_pin_userptr(struct ttm_bo_device *bdev,
>  /*
>   * amdgpu_ttm_tt_unpin_userptr - Unpin and unmap userptr pages
>   */
> -static void amdgpu_ttm_tt_unpin_userptr(struct ttm_bo_device *bdev,
> +static void amdgpu_ttm_tt_unpin_userptr(struct ttm_device *bdev,
>  					struct ttm_tt *ttm)
>  {
>  	struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
> @@ -1015,7 +1015,7 @@ static int amdgpu_ttm_gart_bind(struct amdgpu_device *adev,
>   * Called by ttm_tt_bind() on behalf of ttm_bo_handle_move_mem().
>   * This handles binding GTT memory to the device address space.
>   */
> -static int amdgpu_ttm_backend_bind(struct ttm_bo_device *bdev,
> +static int amdgpu_ttm_backend_bind(struct ttm_device *bdev,
>  				   struct ttm_tt *ttm,
>  				   struct ttm_resource *bo_mem)
>  {
> @@ -1155,7 +1155,7 @@ int amdgpu_ttm_recover_gart(struct ttm_buffer_object *tbo)
>   * Called by ttm_tt_unbind() on behalf of ttm_bo_move_ttm() and
>   * ttm_tt_destroy().
>   */
> -static void amdgpu_ttm_backend_unbind(struct ttm_bo_device *bdev,
> +static void amdgpu_ttm_backend_unbind(struct ttm_device *bdev,
>  				      struct ttm_tt *ttm)
>  {
>  	struct amdgpu_device *adev = amdgpu_ttm_adev(bdev);
> @@ -1180,7 +1180,7 @@ static void amdgpu_ttm_backend_unbind(struct ttm_bo_device *bdev,
>  	gtt->bound = false;
>  }
>  
> -static void amdgpu_ttm_backend_destroy(struct ttm_bo_device *bdev,
> +static void amdgpu_ttm_backend_destroy(struct ttm_device *bdev,
>  				       struct ttm_tt *ttm)
>  {
>  	struct amdgpu_ttm_tt *gtt = (void *)ttm;
> @@ -1234,7 +1234,7 @@ static struct ttm_tt *amdgpu_ttm_tt_create(struct ttm_buffer_object *bo,
>   * Map the pages of a ttm_tt object to an address space visible
>   * to the underlying device.
>   */
> -static int amdgpu_ttm_tt_populate(struct ttm_bo_device *bdev,
> +static int amdgpu_ttm_tt_populate(struct ttm_device *bdev,
>  				  struct ttm_tt *ttm,
>  				  struct ttm_operation_ctx *ctx)
>  {
> @@ -1278,7 +1278,7 @@ static int amdgpu_ttm_tt_populate(struct ttm_bo_device *bdev,
>   * Unmaps pages of a ttm_tt object from the device address space and
>   * unpopulates the page array backing it.
>   */
> -static void amdgpu_ttm_tt_unpopulate(struct ttm_bo_device *bdev,
> +static void amdgpu_ttm_tt_unpopulate(struct ttm_device *bdev,
>  				     struct ttm_tt *ttm)
>  {
>  	struct amdgpu_ttm_tt *gtt = (void *)ttm;
> @@ -1603,7 +1603,7 @@ amdgpu_bo_delete_mem_notify(struct ttm_buffer_object *bo)
>  	amdgpu_bo_move_notify(bo, false, NULL);
>  }
>  
> -static struct ttm_bo_driver amdgpu_bo_driver = {
> +static struct ttm_device_funcs amdgpu_bo_driver = {
>  	.ttm_tt_create = &amdgpu_ttm_tt_create,
>  	.ttm_tt_populate = &amdgpu_ttm_tt_populate,
>  	.ttm_tt_unpopulate = &amdgpu_ttm_tt_unpopulate,
> @@ -1785,7 +1785,7 @@ int amdgpu_ttm_init(struct amdgpu_device *adev)
>  	mutex_init(&adev->mman.gtt_window_lock);
>  
>  	/* No others user of address space so set it to 0 */
> -	r = ttm_bo_device_init(&adev->mman.bdev, &amdgpu_bo_driver, adev->dev,
> +	r = ttm_device_init(&adev->mman.bdev, &amdgpu_bo_driver, adev->dev,
>  			       adev_to_drm(adev)->anon_inode->i_mapping,
>  			       adev_to_drm(adev)->vma_offset_manager,
>  			       adev->need_swiotlb,
> @@ -1926,7 +1926,7 @@ void amdgpu_ttm_fini(struct amdgpu_device *adev)
>  	ttm_range_man_fini(&adev->mman.bdev, AMDGPU_PL_GDS);
>  	ttm_range_man_fini(&adev->mman.bdev, AMDGPU_PL_GWS);
>  	ttm_range_man_fini(&adev->mman.bdev, AMDGPU_PL_OA);
> -	ttm_bo_device_release(&adev->mman.bdev);
> +	ttm_device_fini(&adev->mman.bdev);
>  	adev->mman.initialized = false;
>  	DRM_INFO("amdgpu: ttm finalized\n");
>  }
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h
> index d2987536d7cd..7189f8370108 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.h
> @@ -60,7 +60,7 @@ struct amdgpu_gtt_mgr {
>  };
>  
>  struct amdgpu_mman {
> -	struct ttm_bo_device		bdev;
> +	struct ttm_device		bdev;
>  	bool				initialized;
>  	void __iomem			*aper_base_kaddr;
>  
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
> index ad91c0c3c423..9d19078246c8 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
> @@ -638,15 +638,15 @@ void amdgpu_vm_move_to_lru_tail(struct amdgpu_device *adev,
>  	struct amdgpu_vm_bo_base *bo_base;
>  
>  	if (vm->bulk_moveable) {
> -		spin_lock(&ttm_bo_glob.lru_lock);
> +		spin_lock(&ttm_glob.lru_lock);
>  		ttm_bo_bulk_move_lru_tail(&vm->lru_bulk_move);
> -		spin_unlock(&ttm_bo_glob.lru_lock);
> +		spin_unlock(&ttm_glob.lru_lock);
>  		return;
>  	}
>  
>  	memset(&vm->lru_bulk_move, 0, sizeof(vm->lru_bulk_move));
>  
> -	spin_lock(&ttm_bo_glob.lru_lock);
> +	spin_lock(&ttm_glob.lru_lock);
>  	list_for_each_entry(bo_base, &vm->idle, vm_status) {
>  		struct amdgpu_bo *bo = bo_base->bo;
>  
> @@ -660,7 +660,7 @@ void amdgpu_vm_move_to_lru_tail(struct amdgpu_device *adev,
>  						&bo->shadow->tbo.mem,
>  						&vm->lru_bulk_move);
>  	}
> -	spin_unlock(&ttm_bo_glob.lru_lock);
> +	spin_unlock(&ttm_glob.lru_lock);
>  
>  	vm->bulk_moveable = true;
>  }
> diff --git a/drivers/gpu/drm/drm_gem_vram_helper.c b/drivers/gpu/drm/drm_gem_vram_helper.c
> index 02ca22e90290..0b13c8507688 100644
> --- a/drivers/gpu/drm/drm_gem_vram_helper.c
> +++ b/drivers/gpu/drm/drm_gem_vram_helper.c
> @@ -187,7 +187,7 @@ struct drm_gem_vram_object *drm_gem_vram_create(struct drm_device *dev,
>  	struct drm_gem_vram_object *gbo;
>  	struct drm_gem_object *gem;
>  	struct drm_vram_mm *vmm = dev->vram_mm;
> -	struct ttm_bo_device *bdev;
> +	struct ttm_device *bdev;
>  	int ret;
>  	size_t acc_size;
>  
> @@ -551,7 +551,7 @@ int drm_gem_vram_fill_create_dumb(struct drm_file *file,
>  EXPORT_SYMBOL(drm_gem_vram_fill_create_dumb);
>  
>  /*
> - * Helpers for struct ttm_bo_driver
> + * Helpers for struct ttm_device_funcs
>   */
>  
>  static bool drm_is_gem_vram(struct ttm_buffer_object *bo)
> @@ -893,7 +893,7 @@ static const struct drm_gem_object_funcs drm_gem_vram_object_funcs = {
>   * TTM TT
>   */
>  
> -static void bo_driver_ttm_tt_destroy(struct ttm_bo_device *bdev, struct ttm_tt *tt)
> +static void bo_driver_ttm_tt_destroy(struct ttm_device *bdev, struct ttm_tt *tt)
>  {
>  	ttm_tt_destroy_common(bdev, tt);
>  	ttm_tt_fini(tt);
> @@ -965,7 +965,7 @@ static int bo_driver_move(struct ttm_buffer_object *bo,
>  	return drm_gem_vram_bo_driver_move(gbo, evict, ctx, new_mem);
>  }
>  
> -static int bo_driver_io_mem_reserve(struct ttm_bo_device *bdev,
> +static int bo_driver_io_mem_reserve(struct ttm_device *bdev,
>  				    struct ttm_resource *mem)
>  {
>  	struct drm_vram_mm *vmm = drm_vram_mm_of_bdev(bdev);
> @@ -985,7 +985,7 @@ static int bo_driver_io_mem_reserve(struct ttm_bo_device *bdev,
>  	return 0;
>  }
>  
> -static struct ttm_bo_driver bo_driver = {
> +static struct ttm_device_funcs bo_driver = {
>  	.ttm_tt_create = bo_driver_ttm_tt_create,
>  	.ttm_tt_destroy = bo_driver_ttm_tt_destroy,
>  	.eviction_valuable = ttm_bo_eviction_valuable,
> @@ -1036,7 +1036,7 @@ static int drm_vram_mm_init(struct drm_vram_mm *vmm, struct drm_device *dev,
>  	vmm->vram_base = vram_base;
>  	vmm->vram_size = vram_size;
>  
> -	ret = ttm_bo_device_init(&vmm->bdev, &bo_driver, dev->dev,
> +	ret = ttm_device_init(&vmm->bdev, &bo_driver, dev->dev,
>  				 dev->anon_inode->i_mapping,
>  				 dev->vma_offset_manager,
>  				 false, true);
> @@ -1054,7 +1054,7 @@ static int drm_vram_mm_init(struct drm_vram_mm *vmm, struct drm_device *dev,
>  static void drm_vram_mm_cleanup(struct drm_vram_mm *vmm)
>  {
>  	ttm_range_man_fini(&vmm->bdev, TTM_PL_VRAM);
> -	ttm_bo_device_release(&vmm->bdev);
> +	ttm_device_fini(&vmm->bdev);
>  }
>  
>  /*
> diff --git a/drivers/gpu/drm/nouveau/nouveau_bo.c b/drivers/gpu/drm/nouveau/nouveau_bo.c
> index 33dc886d1d6d..c177940d6e2c 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_bo.c
> +++ b/drivers/gpu/drm/nouveau/nouveau_bo.c
> @@ -43,9 +43,9 @@
>  #include <nvif/if500b.h>
>  #include <nvif/if900b.h>
>  
> -static int nouveau_ttm_tt_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm,
> +static int nouveau_ttm_tt_bind(struct ttm_device *bdev, struct ttm_tt *ttm,
>  			       struct ttm_resource *reg);
> -static void nouveau_ttm_tt_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +static void nouveau_ttm_tt_unbind(struct ttm_device *bdev, struct ttm_tt *ttm);
>  
>  /*
>   * NV10-NV40 tiling helpers
> @@ -674,7 +674,7 @@ nouveau_ttm_tt_create(struct ttm_buffer_object *bo, uint32_t page_flags)
>  }
>  
>  static int
> -nouveau_ttm_tt_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm,
> +nouveau_ttm_tt_bind(struct ttm_device *bdev, struct ttm_tt *ttm,
>  		    struct ttm_resource *reg)
>  {
>  #if IS_ENABLED(CONFIG_AGP)
> @@ -690,7 +690,7 @@ nouveau_ttm_tt_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm,
>  }
>  
>  static void
> -nouveau_ttm_tt_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +nouveau_ttm_tt_unbind(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  #if IS_ENABLED(CONFIG_AGP)
>  	struct nouveau_drm *drm = nouveau_bdev(bdev);
> @@ -1055,7 +1055,7 @@ nouveau_ttm_io_mem_free_locked(struct nouveau_drm *drm,
>  }
>  
>  static int
> -nouveau_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *reg)
> +nouveau_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *reg)
>  {
>  	struct nouveau_drm *drm = nouveau_bdev(bdev);
>  	struct nvkm_device *device = nvxx_device(&drm->client.device);
> @@ -1163,7 +1163,7 @@ nouveau_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *reg)
>  }
>  
>  static void
> -nouveau_ttm_io_mem_free(struct ttm_bo_device *bdev, struct ttm_resource *reg)
> +nouveau_ttm_io_mem_free(struct ttm_device *bdev, struct ttm_resource *reg)
>  {
>  	struct nouveau_drm *drm = nouveau_bdev(bdev);
>  
> @@ -1223,7 +1223,7 @@ vm_fault_t nouveau_ttm_fault_reserve_notify(struct ttm_buffer_object *bo)
>  }
>  
>  static int
> -nouveau_ttm_tt_populate(struct ttm_bo_device *bdev,
> +nouveau_ttm_tt_populate(struct ttm_device *bdev,
>  			struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)
>  {
>  	struct ttm_tt *ttm_dma = (void *)ttm;
> @@ -1247,7 +1247,7 @@ nouveau_ttm_tt_populate(struct ttm_bo_device *bdev,
>  }
>  
>  static void
> -nouveau_ttm_tt_unpopulate(struct ttm_bo_device *bdev,
> +nouveau_ttm_tt_unpopulate(struct ttm_device *bdev,
>  			  struct ttm_tt *ttm)
>  {
>  	struct nouveau_drm *drm;
> @@ -1264,7 +1264,7 @@ nouveau_ttm_tt_unpopulate(struct ttm_bo_device *bdev,
>  }
>  
>  static void
> -nouveau_ttm_tt_destroy(struct ttm_bo_device *bdev,
> +nouveau_ttm_tt_destroy(struct ttm_device *bdev,
>  		       struct ttm_tt *ttm)
>  {
>  #if IS_ENABLED(CONFIG_AGP)
> @@ -1296,7 +1296,7 @@ nouveau_bo_delete_mem_notify(struct ttm_buffer_object *bo)
>  	nouveau_bo_move_ntfy(bo, false, NULL);
>  }
>  
> -struct ttm_bo_driver nouveau_bo_driver = {
> +struct ttm_device_funcs nouveau_bo_driver = {
>  	.ttm_tt_create = &nouveau_ttm_tt_create,
>  	.ttm_tt_populate = &nouveau_ttm_tt_populate,
>  	.ttm_tt_unpopulate = &nouveau_ttm_tt_unpopulate,
> diff --git a/drivers/gpu/drm/nouveau/nouveau_bo.h b/drivers/gpu/drm/nouveau/nouveau_bo.h
> index 6045b85a762a..c2d3f9c48eba 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_bo.h
> +++ b/drivers/gpu/drm/nouveau/nouveau_bo.h
> @@ -68,7 +68,7 @@ nouveau_bo_ref(struct nouveau_bo *ref, struct nouveau_bo **pnvbo)
>  	return 0;
>  }
>  
> -extern struct ttm_bo_driver nouveau_bo_driver;
> +extern struct ttm_device_funcs nouveau_bo_driver;
>  
>  void nouveau_bo_move_init(struct nouveau_drm *);
>  struct nouveau_bo *nouveau_bo_alloc(struct nouveau_cli *, u64 *size, int *align,
> diff --git a/drivers/gpu/drm/nouveau/nouveau_drv.h b/drivers/gpu/drm/nouveau/nouveau_drv.h
> index c802d3d1ba39..edf9d1ee9d58 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_drv.h
> +++ b/drivers/gpu/drm/nouveau/nouveau_drv.h
> @@ -151,7 +151,7 @@ struct nouveau_drm {
>  
>  	/* TTM interface support */
>  	struct {
> -		struct ttm_bo_device bdev;
> +		struct ttm_device bdev;
>  		atomic_t validate_sequence;
>  		int (*move)(struct nouveau_channel *,
>  			    struct ttm_buffer_object *,
> diff --git a/drivers/gpu/drm/nouveau/nouveau_sgdma.c b/drivers/gpu/drm/nouveau/nouveau_sgdma.c
> index 1cf52635ea74..256ec5b35473 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_sgdma.c
> +++ b/drivers/gpu/drm/nouveau/nouveau_sgdma.c
> @@ -16,7 +16,7 @@ struct nouveau_sgdma_be {
>  };
>  
>  void
> -nouveau_sgdma_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +nouveau_sgdma_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  	struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm;
>  
> @@ -29,7 +29,7 @@ nouveau_sgdma_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>  }
>  
>  int
> -nouveau_sgdma_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg)
> +nouveau_sgdma_bind(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg)
>  {
>  	struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm;
>  	struct nouveau_drm *drm = nouveau_bdev(bdev);
> @@ -56,7 +56,7 @@ nouveau_sgdma_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_re
>  }
>  
>  void
> -nouveau_sgdma_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +nouveau_sgdma_unbind(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  	struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm;
>  	if (nvbe->mem) {
> diff --git a/drivers/gpu/drm/nouveau/nouveau_ttm.c b/drivers/gpu/drm/nouveau/nouveau_ttm.c
> index a37bc3d7b38b..495288182c2d 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_ttm.c
> +++ b/drivers/gpu/drm/nouveau/nouveau_ttm.c
> @@ -324,10 +324,10 @@ nouveau_ttm_init(struct nouveau_drm *drm)
>  	need_swiotlb = !!swiotlb_nr_tbl();
>  #endif
>  
> -	ret = ttm_bo_device_init(&drm->ttm.bdev, &nouveau_bo_driver,
> -				 drm->dev->dev, dev->anon_inode->i_mapping,
> -				 dev->vma_offset_manager, need_swiotlb,
> -				 drm->client.mmu.dmabits <= 32);
> +	ret = ttm_device_init(&drm->ttm.bdev, &nouveau_bo_driver, drm->dev->dev,
> +				  dev->anon_inode->i_mapping,
> +				  dev->vma_offset_manager, need_swiotlb,
> +				  drm->client.mmu.dmabits <= 32);
>  	if (ret) {
>  		NV_ERROR(drm, "error initialising bo driver, %d\n", ret);
>  		return ret;
> @@ -377,7 +377,7 @@ nouveau_ttm_fini(struct nouveau_drm *drm)
>  	nouveau_ttm_fini_vram(drm);
>  	nouveau_ttm_fini_gtt(drm);
>  
> -	ttm_bo_device_release(&drm->ttm.bdev);
> +	ttm_device_fini(&drm->ttm.bdev);
>  
>  	arch_phys_wc_del(drm->ttm.mtrr);
>  	drm->ttm.mtrr = 0;
> diff --git a/drivers/gpu/drm/nouveau/nouveau_ttm.h b/drivers/gpu/drm/nouveau/nouveau_ttm.h
> index 69552049bb96..dbf6dc238efd 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_ttm.h
> +++ b/drivers/gpu/drm/nouveau/nouveau_ttm.h
> @@ -3,7 +3,7 @@
>  #define __NOUVEAU_TTM_H__
>  
>  static inline struct nouveau_drm *
> -nouveau_bdev(struct ttm_bo_device *bd)
> +nouveau_bdev(struct ttm_device *bd)
>  {
>  	return container_of(bd, struct nouveau_drm, ttm.bdev);
>  }
> @@ -22,7 +22,7 @@ int  nouveau_ttm_mmap(struct file *, struct vm_area_struct *);
>  int  nouveau_ttm_global_init(struct nouveau_drm *);
>  void nouveau_ttm_global_release(struct nouveau_drm *);
>  
> -int nouveau_sgdma_bind(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg);
> -void nouveau_sgdma_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> -void nouveau_sgdma_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +int nouveau_sgdma_bind(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_resource *reg);
> +void nouveau_sgdma_unbind(struct ttm_device *bdev, struct ttm_tt *ttm);
> +void nouveau_sgdma_destroy(struct ttm_device *bdev, struct ttm_tt *ttm);
>  #endif
> diff --git a/drivers/gpu/drm/qxl/qxl_drv.h b/drivers/gpu/drm/qxl/qxl_drv.h
> index 83b54f0dad61..01354b43c413 100644
> --- a/drivers/gpu/drm/qxl/qxl_drv.h
> +++ b/drivers/gpu/drm/qxl/qxl_drv.h
> @@ -125,7 +125,7 @@ struct qxl_output {
>  #define drm_encoder_to_qxl_output(x) container_of(x, struct qxl_output, enc)
>  
>  struct qxl_mman {
> -	struct ttm_bo_device		bdev;
> +	struct ttm_device		bdev;
>  };
>  
>  struct qxl_memslot {
> @@ -335,7 +335,7 @@ int qxl_mode_dumb_mmap(struct drm_file *filp,
>  /* qxl ttm */
>  int qxl_ttm_init(struct qxl_device *qdev);
>  void qxl_ttm_fini(struct qxl_device *qdev);
> -int qxl_ttm_io_mem_reserve(struct ttm_bo_device *bdev,
> +int qxl_ttm_io_mem_reserve(struct ttm_device *bdev,
>  			   struct ttm_resource *mem);
>  
>  /* qxl image */
> diff --git a/drivers/gpu/drm/qxl/qxl_release.c b/drivers/gpu/drm/qxl/qxl_release.c
> index 0fcfc952d5e9..c52412724c26 100644
> --- a/drivers/gpu/drm/qxl/qxl_release.c
> +++ b/drivers/gpu/drm/qxl/qxl_release.c
> @@ -429,7 +429,7 @@ void qxl_release_unmap(struct qxl_device *qdev,
>  void qxl_release_fence_buffer_objects(struct qxl_release *release)
>  {
>  	struct ttm_buffer_object *bo;
> -	struct ttm_bo_device *bdev;
> +	struct ttm_device *bdev;
>  	struct ttm_validate_buffer *entry;
>  	struct qxl_device *qdev;
>  
> @@ -450,7 +450,7 @@ void qxl_release_fence_buffer_objects(struct qxl_release *release)
>  		       release->id | 0xf0000000, release->base.seqno);
>  	trace_dma_fence_emit(&release->base);
>  
> -	spin_lock(&ttm_bo_glob.lru_lock);
> +	spin_lock(&ttm_glob.lru_lock);
>  
>  	list_for_each_entry(entry, &release->bos, head) {
>  		bo = entry->bo;
> @@ -459,7 +459,7 @@ void qxl_release_fence_buffer_objects(struct qxl_release *release)
>  		ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
>  		dma_resv_unlock(bo->base.resv);
>  	}
> -	spin_unlock(&ttm_bo_glob.lru_lock);
> +	spin_unlock(&ttm_glob.lru_lock);
>  	ww_acquire_fini(&release->ticket);
>  }
>  
> diff --git a/drivers/gpu/drm/qxl/qxl_ttm.c b/drivers/gpu/drm/qxl/qxl_ttm.c
> index 33c09dc94f8b..b7f77eb685cb 100644
> --- a/drivers/gpu/drm/qxl/qxl_ttm.c
> +++ b/drivers/gpu/drm/qxl/qxl_ttm.c
> @@ -36,7 +36,7 @@
>  #include "qxl_drv.h"
>  #include "qxl_object.h"
>  
> -static struct qxl_device *qxl_get_qdev(struct ttm_bo_device *bdev)
> +static struct qxl_device *qxl_get_qdev(struct ttm_device *bdev)
>  {
>  	struct qxl_mman *mman;
>  	struct qxl_device *qdev;
> @@ -69,7 +69,7 @@ static void qxl_evict_flags(struct ttm_buffer_object *bo,
>  	*placement = qbo->placement;
>  }
>  
> -int qxl_ttm_io_mem_reserve(struct ttm_bo_device *bdev,
> +int qxl_ttm_io_mem_reserve(struct ttm_device *bdev,
>  			   struct ttm_resource *mem)
>  {
>  	struct qxl_device *qdev = qxl_get_qdev(bdev);
> @@ -98,8 +98,7 @@ int qxl_ttm_io_mem_reserve(struct ttm_bo_device *bdev,
>  /*
>   * TTM backend functions.
>   */
> -static void qxl_ttm_backend_destroy(struct ttm_bo_device *bdev,
> -				    struct ttm_tt *ttm)
> +static void qxl_ttm_backend_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  	ttm_tt_destroy_common(bdev, ttm);
>  	ttm_tt_fini(ttm);
> @@ -170,7 +169,7 @@ static void qxl_bo_delete_mem_notify(struct ttm_buffer_object *bo)
>  	qxl_bo_move_notify(bo, false, NULL);
>  }
>  
> -static struct ttm_bo_driver qxl_bo_driver = {
> +static struct ttm_device_funcs qxl_bo_driver = {
>  	.ttm_tt_create = &qxl_ttm_tt_create,
>  	.ttm_tt_destroy = &qxl_ttm_backend_destroy,
>  	.eviction_valuable = ttm_bo_eviction_valuable,
> @@ -193,10 +192,10 @@ int qxl_ttm_init(struct qxl_device *qdev)
>  	int num_io_pages; /* != rom->num_io_pages, we include surface0 */
>  
>  	/* No others user of address space so set it to 0 */
> -	r = ttm_bo_device_init(&qdev->mman.bdev, &qxl_bo_driver, NULL,
> -			       qdev->ddev.anon_inode->i_mapping,
> -			       qdev->ddev.vma_offset_manager,
> -			       false, false);
> +	r = ttm_device_init(&qdev->mman.bdev, &qxl_bo_driver, NULL,
> +			    qdev->ddev.anon_inode->i_mapping,
> +			    qdev->ddev.vma_offset_manager,
> +			    false, false);
>  	if (r) {
>  		DRM_ERROR("failed initializing buffer object driver(%d).\n", r);
>  		return r;
> @@ -227,7 +226,7 @@ void qxl_ttm_fini(struct qxl_device *qdev)
>  {
>  	ttm_range_man_fini(&qdev->mman.bdev, TTM_PL_VRAM);
>  	ttm_range_man_fini(&qdev->mman.bdev, TTM_PL_PRIV);
> -	ttm_bo_device_release(&qdev->mman.bdev);
> +	ttm_device_fini(&qdev->mman.bdev);
>  	DRM_INFO("qxl: ttm finalized\n");
>  }
>  
> diff --git a/drivers/gpu/drm/radeon/radeon.h b/drivers/gpu/drm/radeon/radeon.h
> index f09989bdce98..449ba0095ed9 100644
> --- a/drivers/gpu/drm/radeon/radeon.h
> +++ b/drivers/gpu/drm/radeon/radeon.h
> @@ -451,7 +451,7 @@ struct radeon_surface_reg {
>   * TTM.
>   */
>  struct radeon_mman {
> -	struct ttm_bo_device		bdev;
> +	struct ttm_device		bdev;
>  	bool				initialized;
>  
>  #if defined(CONFIG_DEBUG_FS)
> @@ -2822,7 +2822,7 @@ extern int radeon_ttm_tt_set_userptr(struct radeon_device *rdev,
>  				     uint32_t flags);
>  extern bool radeon_ttm_tt_has_userptr(struct radeon_device *rdev, struct ttm_tt *ttm);
>  extern bool radeon_ttm_tt_is_readonly(struct radeon_device *rdev, struct ttm_tt *ttm);
> -bool radeon_ttm_tt_is_bound(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +bool radeon_ttm_tt_is_bound(struct ttm_device *bdev, struct ttm_tt *ttm);
>  extern void radeon_vram_location(struct radeon_device *rdev, struct radeon_mc *mc, u64 base);
>  extern void radeon_gtt_location(struct radeon_device *rdev, struct radeon_mc *mc);
>  extern int radeon_resume_kms(struct drm_device *dev, bool resume, bool fbcon);
> @@ -2832,7 +2832,7 @@ extern void radeon_ttm_set_active_vram_size(struct radeon_device *rdev, u64 size
>  extern void radeon_program_register_sequence(struct radeon_device *rdev,
>  					     const u32 *registers,
>  					     const u32 array_size);
> -struct radeon_device *radeon_get_rdev(struct ttm_bo_device *bdev);
> +struct radeon_device *radeon_get_rdev(struct ttm_device *bdev);
>  
>  /* KMS */
>  
> diff --git a/drivers/gpu/drm/radeon/radeon_object.c b/drivers/gpu/drm/radeon/radeon_object.c
> index 9b81786782de..6a336284466f 100644
> --- a/drivers/gpu/drm/radeon/radeon_object.c
> +++ b/drivers/gpu/drm/radeon/radeon_object.c
> @@ -372,7 +372,7 @@ void radeon_bo_unpin(struct radeon_bo *bo)
>  
>  int radeon_bo_evict_vram(struct radeon_device *rdev)
>  {
> -	struct ttm_bo_device *bdev = &rdev->mman.bdev;
> +	struct ttm_device *bdev = &rdev->mman.bdev;
>  	struct ttm_resource_manager *man;
>  
>  	/* late 2.6.33 fix IGP hibernate - we need pm ops to do this correct */
> diff --git a/drivers/gpu/drm/radeon/radeon_ttm.c b/drivers/gpu/drm/radeon/radeon_ttm.c
> index c6d575f50c48..5ed6a48246d6 100644
> --- a/drivers/gpu/drm/radeon/radeon_ttm.c
> +++ b/drivers/gpu/drm/radeon/radeon_ttm.c
> @@ -55,13 +55,11 @@
>  static int radeon_ttm_debugfs_init(struct radeon_device *rdev);
>  static void radeon_ttm_debugfs_fini(struct radeon_device *rdev);
>  
> -static int radeon_ttm_tt_bind(struct ttm_bo_device *bdev,
> -			      struct ttm_tt *ttm,
> +static int radeon_ttm_tt_bind(struct ttm_device *bdev, struct ttm_tt *ttm,
>  			      struct ttm_resource *bo_mem);
> -static void radeon_ttm_tt_unbind(struct ttm_bo_device *bdev,
> -				 struct ttm_tt *ttm);
> +static void radeon_ttm_tt_unbind(struct ttm_device *bdev, struct ttm_tt *ttm);
>  
> -struct radeon_device *radeon_get_rdev(struct ttm_bo_device *bdev)
> +struct radeon_device *radeon_get_rdev(struct ttm_device *bdev)
>  {
>  	struct radeon_mman *mman;
>  	struct radeon_device *rdev;
> @@ -280,7 +278,7 @@ static int radeon_bo_move(struct ttm_buffer_object *bo, bool evict,
>  	return 0;
>  }
>  
> -static int radeon_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *mem)
> +static int radeon_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *mem)
>  {
>  	struct radeon_device *rdev = radeon_get_rdev(bdev);
>  	size_t bus_size = (size_t)mem->num_pages << PAGE_SHIFT;
> @@ -347,7 +345,7 @@ struct radeon_ttm_tt {
>  };
>  
>  /* prepare the sg table with the user pages */
> -static int radeon_ttm_tt_pin_userptr(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static int radeon_ttm_tt_pin_userptr(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  	struct radeon_device *rdev = radeon_get_rdev(bdev);
>  	struct radeon_ttm_tt *gtt = (void *)ttm;
> @@ -408,7 +406,7 @@ static int radeon_ttm_tt_pin_userptr(struct ttm_bo_device *bdev, struct ttm_tt *
>  	return r;
>  }
>  
> -static void radeon_ttm_tt_unpin_userptr(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static void radeon_ttm_tt_unpin_userptr(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  	struct radeon_device *rdev = radeon_get_rdev(bdev);
>  	struct radeon_ttm_tt *gtt = (void *)ttm;
> @@ -444,7 +442,7 @@ static bool radeon_ttm_backend_is_bound(struct ttm_tt *ttm)
>  	return (gtt->bound);
>  }
>  
> -static int radeon_ttm_backend_bind(struct ttm_bo_device *bdev,
> +static int radeon_ttm_backend_bind(struct ttm_device *bdev,
>  				   struct ttm_tt *ttm,
>  				   struct ttm_resource *bo_mem)
>  {
> @@ -480,7 +478,7 @@ static int radeon_ttm_backend_bind(struct ttm_bo_device *bdev,
>  	return 0;
>  }
>  
> -static void radeon_ttm_backend_unbind(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static void radeon_ttm_backend_unbind(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  	struct radeon_ttm_tt *gtt = (void *)ttm;
>  	struct radeon_device *rdev = radeon_get_rdev(bdev);
> @@ -495,7 +493,7 @@ static void radeon_ttm_backend_unbind(struct ttm_bo_device *bdev, struct ttm_tt
>  	gtt->bound = false;
>  }
>  
> -static void radeon_ttm_backend_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static void radeon_ttm_backend_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  	struct radeon_ttm_tt *gtt = (void *)ttm;
>  
> @@ -554,7 +552,7 @@ static struct radeon_ttm_tt *radeon_ttm_tt_to_gtt(struct radeon_device *rdev,
>  	return container_of(ttm, struct radeon_ttm_tt, ttm);
>  }
>  
> -static int radeon_ttm_tt_populate(struct ttm_bo_device *bdev,
> +static int radeon_ttm_tt_populate(struct ttm_device *bdev,
>  				  struct ttm_tt *ttm,
>  				  struct ttm_operation_ctx *ctx)
>  {
> @@ -580,7 +578,7 @@ static int radeon_ttm_tt_populate(struct ttm_bo_device *bdev,
>  	return ttm_pool_alloc(&rdev->mman.bdev.pool, ttm, ctx);
>  }
>  
> -static void radeon_ttm_tt_unpopulate(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static void radeon_ttm_tt_unpopulate(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  	struct radeon_device *rdev = radeon_get_rdev(bdev);
>  	struct radeon_ttm_tt *gtt = radeon_ttm_tt_to_gtt(rdev, ttm);
> @@ -613,7 +611,7 @@ int radeon_ttm_tt_set_userptr(struct radeon_device *rdev,
>  	return 0;
>  }
>  
> -bool radeon_ttm_tt_is_bound(struct ttm_bo_device *bdev,
> +bool radeon_ttm_tt_is_bound(struct ttm_device *bdev,
>  			    struct ttm_tt *ttm)
>  {
>  #if IS_ENABLED(CONFIG_AGP)
> @@ -624,7 +622,7 @@ bool radeon_ttm_tt_is_bound(struct ttm_bo_device *bdev,
>  	return radeon_ttm_backend_is_bound(ttm);
>  }
>  
> -static int radeon_ttm_tt_bind(struct ttm_bo_device *bdev,
> +static int radeon_ttm_tt_bind(struct ttm_device *bdev,
>  			      struct ttm_tt *ttm,
>  			      struct ttm_resource *bo_mem)
>  {
> @@ -642,7 +640,7 @@ static int radeon_ttm_tt_bind(struct ttm_bo_device *bdev,
>  	return radeon_ttm_backend_bind(bdev, ttm, bo_mem);
>  }
>  
> -static void radeon_ttm_tt_unbind(struct ttm_bo_device *bdev,
> +static void radeon_ttm_tt_unbind(struct ttm_device *bdev,
>  				 struct ttm_tt *ttm)
>  {
>  #if IS_ENABLED(CONFIG_AGP)
> @@ -656,7 +654,7 @@ static void radeon_ttm_tt_unbind(struct ttm_bo_device *bdev,
>  	radeon_ttm_backend_unbind(bdev, ttm);
>  }
>  
> -static void radeon_ttm_tt_destroy(struct ttm_bo_device *bdev,
> +static void radeon_ttm_tt_destroy(struct ttm_device *bdev,
>  				  struct ttm_tt *ttm)
>  {
>  #if IS_ENABLED(CONFIG_AGP)
> @@ -700,7 +698,7 @@ radeon_bo_delete_mem_notify(struct ttm_buffer_object *bo)
>  	radeon_bo_move_notify(bo, false, NULL);
>  }
>  
> -static struct ttm_bo_driver radeon_bo_driver = {
> +static struct ttm_device_funcs radeon_bo_driver = {
>  	.ttm_tt_create = &radeon_ttm_tt_create,
>  	.ttm_tt_populate = &radeon_ttm_tt_populate,
>  	.ttm_tt_unpopulate = &radeon_ttm_tt_unpopulate,
> @@ -718,7 +716,7 @@ int radeon_ttm_init(struct radeon_device *rdev)
>  	int r;
>  
>  	/* No others user of address space so set it to 0 */
> -	r = ttm_bo_device_init(&rdev->mman.bdev, &radeon_bo_driver, rdev->dev,
> +	r = ttm_device_init(&rdev->mman.bdev, &radeon_bo_driver, rdev->dev,
>  			       rdev->ddev->anon_inode->i_mapping,
>  			       rdev->ddev->vma_offset_manager,
>  			       rdev->need_swiotlb,
> @@ -791,7 +789,7 @@ void radeon_ttm_fini(struct radeon_device *rdev)
>  	}
>  	ttm_range_man_fini(&rdev->mman.bdev, TTM_PL_VRAM);
>  	ttm_range_man_fini(&rdev->mman.bdev, TTM_PL_TT);
> -	ttm_bo_device_release(&rdev->mman.bdev);
> +	ttm_device_fini(&rdev->mman.bdev);
>  	radeon_gart_fini(rdev);
>  	rdev->mman.initialized = false;
>  	DRM_INFO("radeon: ttm finalized\n");
> diff --git a/drivers/gpu/drm/ttm/Makefile b/drivers/gpu/drm/ttm/Makefile
> index b6f5f87b270f..8e6437eadabe 100644
> --- a/drivers/gpu/drm/ttm/Makefile
> +++ b/drivers/gpu/drm/ttm/Makefile
> @@ -5,7 +5,7 @@
>  ttm-y := ttm_memory.o ttm_tt.o ttm_bo.o \
>  	ttm_bo_util.o ttm_bo_vm.o ttm_module.o \
>  	ttm_execbuf_util.o ttm_range_manager.o \
> -	ttm_resource.o ttm_pool.o
> +	ttm_resource.o ttm_pool.o ttm_device.o
>  ttm-$(CONFIG_AGP) += ttm_agp_backend.o
>  
>  obj-$(CONFIG_DRM_TTM) += ttm.o
> diff --git a/drivers/gpu/drm/ttm/ttm_agp_backend.c b/drivers/gpu/drm/ttm/ttm_agp_backend.c
> index 8f9fa4188897..0226ae69d3ab 100644
> --- a/drivers/gpu/drm/ttm/ttm_agp_backend.c
> +++ b/drivers/gpu/drm/ttm/ttm_agp_backend.c
> @@ -49,7 +49,7 @@ struct ttm_agp_backend {
>  int ttm_agp_bind(struct ttm_tt *ttm, struct ttm_resource *bo_mem)
>  {
>  	struct ttm_agp_backend *agp_be = container_of(ttm, struct ttm_agp_backend, ttm);
> -	struct page *dummy_read_page = ttm_bo_glob.dummy_read_page;
> +	struct page *dummy_read_page = ttm_glob.dummy_read_page;
>  	struct drm_mm_node *node = bo_mem->mm_node;
>  	struct agp_memory *mem;
>  	int ret, cached = ttm->caching == ttm_cached;
> diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c
> index c289a6a37ff9..20256797f3a6 100644
> --- a/drivers/gpu/drm/ttm/ttm_bo.c
> +++ b/drivers/gpu/drm/ttm/ttm_bo.c
> @@ -44,14 +44,6 @@
>  
>  #include "ttm_module.h"
>  
> -/*
> - * ttm_global_mutex - protecting the global BO state
> - */
> -DEFINE_MUTEX(ttm_global_mutex);
> -unsigned ttm_bo_glob_use_count;
> -struct ttm_bo_global ttm_bo_glob;
> -EXPORT_SYMBOL(ttm_bo_glob);
> -
>  /* default destructor */
>  static void ttm_bo_default_destroy(struct ttm_buffer_object *bo)
>  {
> @@ -79,13 +71,13 @@ static void ttm_bo_mem_space_debug(struct ttm_buffer_object *bo,
>  
>  static void ttm_bo_del_from_lru(struct ttm_buffer_object *bo)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  
>  	list_del_init(&bo->swap);
>  	list_del_init(&bo->lru);
>  
> -	if (bdev->driver->del_from_lru_notify)
> -		bdev->driver->del_from_lru_notify(bo);
> +	if (bdev->funcs->del_from_lru_notify)
> +		bdev->funcs->del_from_lru_notify(bo);
>  }
>  
>  static void ttm_bo_bulk_move_set_pos(struct ttm_lru_bulk_move_pos *pos,
> @@ -100,7 +92,7 @@ void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
>  			     struct ttm_resource *mem,
>  			     struct ttm_lru_bulk_move *bulk)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  	struct ttm_resource_manager *man;
>  
>  	dma_resv_assert_held(bo->base.resv);
> @@ -117,12 +109,12 @@ void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
>  				     TTM_PAGE_FLAG_SWAPPED))) {
>  		struct list_head *swap;
>  
> -		swap = &ttm_bo_glob.swap_lru[bo->priority];
> +		swap = &ttm_glob.swap_lru[bo->priority];
>  		list_move_tail(&bo->swap, swap);
>  	}
>  
> -	if (bdev->driver->del_from_lru_notify)
> -		bdev->driver->del_from_lru_notify(bo);
> +	if (bdev->funcs->del_from_lru_notify)
> +		bdev->funcs->del_from_lru_notify(bo);
>  
>  	if (bulk && !bo->pin_count) {
>  		switch (bo->mem.mem_type) {
> @@ -185,7 +177,7 @@ void ttm_bo_bulk_move_lru_tail(struct ttm_lru_bulk_move *bulk)
>  		dma_resv_assert_held(pos->first->base.resv);
>  		dma_resv_assert_held(pos->last->base.resv);
>  
> -		lru = &ttm_bo_glob.swap_lru[i];
> +		lru = &ttm_glob.swap_lru[i];
>  		list_bulk_move_tail(lru, &pos->first->swap, &pos->last->swap);
>  	}
>  }
> @@ -196,7 +188,7 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
>  				  struct ttm_operation_ctx *ctx,
>  				  struct ttm_place *hop)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  	struct ttm_resource_manager *old_man = ttm_manager_type(bdev, bo->mem.mem_type);
>  	struct ttm_resource_manager *new_man = ttm_manager_type(bdev, mem->mem_type);
>  	int ret;
> @@ -222,7 +214,7 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
>  		}
>  	}
>  
> -	ret = bdev->driver->move(bo, evict, ctx, mem, hop);
> +	ret = bdev->funcs->move(bo, evict, ctx, mem, hop);
>  	if (ret) {
>  		if (ret == -EMULTIHOP)
>  			return ret;
> @@ -250,8 +242,8 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
>  
>  static void ttm_bo_cleanup_memtype_use(struct ttm_buffer_object *bo)
>  {
> -	if (bo->bdev->driver->delete_mem_notify)
> -		bo->bdev->driver->delete_mem_notify(bo);
> +	if (bo->bdev->funcs->delete_mem_notify)
> +		bo->bdev->funcs->delete_mem_notify(bo);
>  
>  	ttm_bo_tt_destroy(bo);
>  	ttm_resource_free(bo, &bo->mem);
> @@ -276,9 +268,9 @@ static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
>  		 * 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);
> +		spin_lock(&ttm_glob.lru_lock);
>  		bo->base.resv = &bo->base._resv;
> -		spin_unlock(&ttm_bo_glob.lru_lock);
> +		spin_unlock(&ttm_glob.lru_lock);
>  	}
>  
>  	return r;
> @@ -337,7 +329,7 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>  
>  		if (unlock_resv)
>  			dma_resv_unlock(bo->base.resv);
> -		spin_unlock(&ttm_bo_glob.lru_lock);
> +		spin_unlock(&ttm_glob.lru_lock);
>  
>  		lret = dma_resv_wait_timeout_rcu(resv, true, interruptible,
>  						 30 * HZ);
> @@ -347,7 +339,7 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>  		else if (lret == 0)
>  			return -EBUSY;
>  
> -		spin_lock(&ttm_bo_glob.lru_lock);
> +		spin_lock(&ttm_glob.lru_lock);
>  		if (unlock_resv && !dma_resv_trylock(bo->base.resv)) {
>  			/*
>  			 * We raced, and lost, someone else holds the reservation now,
> @@ -357,7 +349,7 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>  			 * delayed destruction would succeed, so just return success
>  			 * here.
>  			 */
> -			spin_unlock(&ttm_bo_glob.lru_lock);
> +			spin_unlock(&ttm_glob.lru_lock);
>  			return 0;
>  		}
>  		ret = 0;
> @@ -366,13 +358,13 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>  	if (ret || unlikely(list_empty(&bo->ddestroy))) {
>  		if (unlock_resv)
>  			dma_resv_unlock(bo->base.resv);
> -		spin_unlock(&ttm_bo_glob.lru_lock);
> +		spin_unlock(&ttm_glob.lru_lock);
>  		return ret;
>  	}
>  
>  	ttm_bo_del_from_lru(bo);
>  	list_del_init(&bo->ddestroy);
> -	spin_unlock(&ttm_bo_glob.lru_lock);
> +	spin_unlock(&ttm_glob.lru_lock);
>  	ttm_bo_cleanup_memtype_use(bo);
>  
>  	if (unlock_resv)
> @@ -387,9 +379,9 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo,
>   * Traverse the delayed list, and call ttm_bo_cleanup_refs on all
>   * encountered buffers.
>   */
> -static bool ttm_bo_delayed_delete(struct ttm_bo_device *bdev, bool remove_all)
> +bool ttm_bo_delayed_delete(struct ttm_device *bdev, bool remove_all)
>  {
> -	struct ttm_bo_global *glob = &ttm_bo_glob;
> +	struct ttm_global *glob = &ttm_glob;
>  	struct list_head removed;
>  	bool empty;
>  
> @@ -428,21 +420,11 @@ static bool ttm_bo_delayed_delete(struct ttm_bo_device *bdev, bool remove_all)
>  	return empty;
>  }
>  
> -static void ttm_bo_delayed_workqueue(struct work_struct *work)
> -{
> -	struct ttm_bo_device *bdev =
> -	    container_of(work, struct ttm_bo_device, wq.work);
> -
> -	if (!ttm_bo_delayed_delete(bdev, false))
> -		schedule_delayed_work(&bdev->wq,
> -				      ((HZ / 100) < 1) ? 1 : HZ / 100);
> -}
> -
>  static void ttm_bo_release(struct kref *kref)
>  {
>  	struct ttm_buffer_object *bo =
>  	    container_of(kref, struct ttm_buffer_object, kref);
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  	size_t acc_size = bo->acc_size;
>  	int ret;
>  
> @@ -456,8 +438,8 @@ static void ttm_bo_release(struct kref *kref)
>  						  30 * HZ);
>  		}
>  
> -		if (bo->bdev->driver->release_notify)
> -			bo->bdev->driver->release_notify(bo);
> +		if (bo->bdev->funcs->release_notify)
> +			bo->bdev->funcs->release_notify(bo);
>  
>  		drm_vma_offset_remove(bdev->vma_manager, &bo->base.vma_node);
>  		ttm_mem_io_free(bdev, &bo->mem);
> @@ -469,7 +451,7 @@ static void ttm_bo_release(struct kref *kref)
>  		ttm_bo_flush_all_fences(bo);
>  		bo->deleted = true;
>  
> -		spin_lock(&ttm_bo_glob.lru_lock);
> +		spin_lock(&ttm_glob.lru_lock);
>  
>  		/*
>  		 * Make pinned bos immediately available to
> @@ -483,22 +465,22 @@ static void ttm_bo_release(struct kref *kref)
>  
>  		kref_init(&bo->kref);
>  		list_add_tail(&bo->ddestroy, &bdev->ddestroy);
> -		spin_unlock(&ttm_bo_glob.lru_lock);
> +		spin_unlock(&ttm_glob.lru_lock);
>  
>  		schedule_delayed_work(&bdev->wq,
>  				      ((HZ / 100) < 1) ? 1 : HZ / 100);
>  		return;
>  	}
>  
> -	spin_lock(&ttm_bo_glob.lru_lock);
> +	spin_lock(&ttm_glob.lru_lock);
>  	ttm_bo_del_from_lru(bo);
>  	list_del(&bo->ddestroy);
> -	spin_unlock(&ttm_bo_glob.lru_lock);
> +	spin_unlock(&ttm_glob.lru_lock);
>  
>  	ttm_bo_cleanup_memtype_use(bo);
>  	dma_resv_unlock(bo->base.resv);
>  
> -	atomic_dec(&ttm_bo_glob.bo_count);
> +	atomic_dec(&ttm_glob.bo_count);
>  	dma_fence_put(bo->moving);
>  	if (!ttm_bo_uses_embedded_gem_object(bo))
>  		dma_resv_fini(&bo->base._resv);
> @@ -512,13 +494,13 @@ void ttm_bo_put(struct ttm_buffer_object *bo)
>  }
>  EXPORT_SYMBOL(ttm_bo_put);
>  
> -int ttm_bo_lock_delayed_workqueue(struct ttm_bo_device *bdev)
> +int ttm_bo_lock_delayed_workqueue(struct ttm_device *bdev)
>  {
>  	return cancel_delayed_work_sync(&bdev->wq);
>  }
>  EXPORT_SYMBOL(ttm_bo_lock_delayed_workqueue);
>  
> -void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev, int resched)
> +void ttm_bo_unlock_delayed_workqueue(struct ttm_device *bdev, int resched)
>  {
>  	if (resched)
>  		schedule_delayed_work(&bdev->wq,
> @@ -529,7 +511,7 @@ EXPORT_SYMBOL(ttm_bo_unlock_delayed_workqueue);
>  static int ttm_bo_evict(struct ttm_buffer_object *bo,
>  			struct ttm_operation_ctx *ctx)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  	struct ttm_resource evict_mem;
>  	struct ttm_placement placement;
>  	struct ttm_place hop;
> @@ -541,7 +523,7 @@ static int ttm_bo_evict(struct ttm_buffer_object *bo,
>  
>  	placement.num_placement = 0;
>  	placement.num_busy_placement = 0;
> -	bdev->driver->evict_flags(bo, &placement);
> +	bdev->funcs->evict_flags(bo, &placement);
>  
>  	if (!placement.num_placement && !placement.num_busy_placement) {
>  		ttm_bo_wait(bo, false, false);
> @@ -657,7 +639,7 @@ static int ttm_mem_evict_wait_busy(struct ttm_buffer_object *busy_bo,
>  	return r == -EDEADLK ? -EBUSY : r;
>  }
>  
> -int ttm_mem_evict_first(struct ttm_bo_device *bdev,
> +int ttm_mem_evict_first(struct ttm_device *bdev,
>  			struct ttm_resource_manager *man,
>  			const struct ttm_place *place,
>  			struct ttm_operation_ctx *ctx,
> @@ -668,7 +650,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>  	unsigned i;
>  	int ret;
>  
> -	spin_lock(&ttm_bo_glob.lru_lock);
> +	spin_lock(&ttm_glob.lru_lock);
>  	for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i) {
>  		list_for_each_entry(bo, &man->lru[i], lru) {
>  			bool busy;
> @@ -681,7 +663,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>  				continue;
>  			}
>  
> -			if (place && !bdev->driver->eviction_valuable(bo,
> +			if (place && !bdev->funcs->eviction_valuable(bo,
>  								      place)) {
>  				if (locked)
>  					dma_resv_unlock(bo->base.resv);
> @@ -705,7 +687,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>  	if (!bo) {
>  		if (busy_bo && !ttm_bo_get_unless_zero(busy_bo))
>  			busy_bo = NULL;
> -		spin_unlock(&ttm_bo_glob.lru_lock);
> +		spin_unlock(&ttm_glob.lru_lock);
>  		ret = ttm_mem_evict_wait_busy(busy_bo, ctx, ticket);
>  		if (busy_bo)
>  			ttm_bo_put(busy_bo);
> @@ -719,7 +701,7 @@ int ttm_mem_evict_first(struct ttm_bo_device *bdev,
>  		return ret;
>  	}
>  
> -	spin_unlock(&ttm_bo_glob.lru_lock);
> +	spin_unlock(&ttm_glob.lru_lock);
>  
>  	ret = ttm_bo_evict(bo, ctx);
>  	if (locked)
> @@ -774,7 +756,7 @@ static int ttm_bo_mem_force_space(struct ttm_buffer_object *bo,
>  				  struct ttm_resource *mem,
>  				  struct ttm_operation_ctx *ctx)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  	struct ttm_resource_manager *man = ttm_manager_type(bdev, mem->mem_type);
>  	struct ww_acquire_ctx *ticket;
>  	int ret;
> @@ -809,7 +791,7 @@ static int ttm_bo_mem_placement(struct ttm_buffer_object *bo,
>  				const struct ttm_place *place,
>  				struct ttm_resource *mem)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  	struct ttm_resource_manager *man;
>  
>  	man = ttm_manager_type(bdev, place->mem_type);
> @@ -819,9 +801,9 @@ static int ttm_bo_mem_placement(struct ttm_buffer_object *bo,
>  	mem->mem_type = place->mem_type;
>  	mem->placement = place->flags;
>  
> -	spin_lock(&ttm_bo_glob.lru_lock);
> +	spin_lock(&ttm_glob.lru_lock);
>  	ttm_bo_move_to_lru_tail(bo, mem, NULL);
> -	spin_unlock(&ttm_bo_glob.lru_lock);
> +	spin_unlock(&ttm_glob.lru_lock);
>  
>  	return 0;
>  }
> @@ -839,7 +821,7 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
>  			struct ttm_resource *mem,
>  			struct ttm_operation_ctx *ctx)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  	bool type_found = false;
>  	int i, ret;
>  
> @@ -1057,7 +1039,7 @@ int ttm_bo_validate(struct ttm_buffer_object *bo,
>  }
>  EXPORT_SYMBOL(ttm_bo_validate);
>  
> -int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
> +int ttm_bo_init_reserved(struct ttm_device *bdev,
>  			 struct ttm_buffer_object *bo,
>  			 size_t size,
>  			 enum ttm_bo_type type,
> @@ -1117,7 +1099,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>  		dma_resv_init(&bo->base._resv);
>  		drm_vma_node_reset(&bo->base.vma_node);
>  	}
> -	atomic_inc(&ttm_bo_glob.bo_count);
> +	atomic_inc(&ttm_glob.bo_count);
>  
>  	/*
>  	 * For ttm_bo_type_device buffers, allocate
> @@ -1153,7 +1135,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>  }
>  EXPORT_SYMBOL(ttm_bo_init_reserved);
>  
> -int ttm_bo_init(struct ttm_bo_device *bdev,
> +int ttm_bo_init(struct ttm_device *bdev,
>  		struct ttm_buffer_object *bo,
>  		size_t size,
>  		enum ttm_bo_type type,
> @@ -1181,7 +1163,7 @@ int ttm_bo_init(struct ttm_bo_device *bdev,
>  }
>  EXPORT_SYMBOL(ttm_bo_init);
>  
> -size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
> +size_t ttm_bo_dma_acc_size(struct ttm_device *bdev,
>  			   unsigned long bo_size,
>  			   unsigned struct_size)
>  {
> @@ -1195,148 +1177,13 @@ size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
>  }
>  EXPORT_SYMBOL(ttm_bo_dma_acc_size);
>  
> -static void ttm_bo_global_release(void)
> -{
> -	struct ttm_bo_global *glob = &ttm_bo_glob;
> -
> -	mutex_lock(&ttm_global_mutex);
> -	if (--ttm_bo_glob_use_count > 0)
> -		goto out;
> -
> -	kobject_del(&glob->kobj);
> -	kobject_put(&glob->kobj);
> -	ttm_mem_global_release(&ttm_mem_glob);
> -	__free_page(glob->dummy_read_page);
> -	memset(glob, 0, sizeof(*glob));
> -out:
> -	mutex_unlock(&ttm_global_mutex);
> -}
> -
> -static int ttm_bo_global_init(void)
> -{
> -	struct ttm_bo_global *glob = &ttm_bo_glob;
> -	int ret = 0;
> -	unsigned i;
> -
> -	mutex_lock(&ttm_global_mutex);
> -	if (++ttm_bo_glob_use_count > 1)
> -		goto out;
> -
> -	ret = ttm_mem_global_init(&ttm_mem_glob);
> -	if (ret)
> -		goto out;
> -
> -	spin_lock_init(&glob->lru_lock);
> -	glob->dummy_read_page = alloc_page(__GFP_ZERO | GFP_DMA32);
> -
> -	if (unlikely(glob->dummy_read_page == NULL)) {
> -		ret = -ENOMEM;
> -		goto out;
> -	}
> -
> -	for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
> -		INIT_LIST_HEAD(&glob->swap_lru[i]);
> -	INIT_LIST_HEAD(&glob->device_list);
> -	atomic_set(&glob->bo_count, 0);
> -
> -	debugfs_create_atomic_t("buffer_objects", 0444, ttm_debugfs_root,
> -				&glob->bo_count);
> -out:
> -	mutex_unlock(&ttm_global_mutex);
> -	return ret;
> -}
> -
> -int ttm_bo_device_release(struct ttm_bo_device *bdev)
> -{
> -	struct ttm_bo_global *glob = &ttm_bo_glob;
> -	int ret = 0;
> -	unsigned i;
> -	struct ttm_resource_manager *man;
> -
> -	man = ttm_manager_type(bdev, TTM_PL_SYSTEM);
> -	ttm_resource_manager_set_used(man, false);
> -	ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, NULL);
> -
> -	mutex_lock(&ttm_global_mutex);
> -	list_del(&bdev->device_list);
> -	mutex_unlock(&ttm_global_mutex);
> -
> -	cancel_delayed_work_sync(&bdev->wq);
> -
> -	if (ttm_bo_delayed_delete(bdev, true))
> -		pr_debug("Delayed destroy list was clean\n");
> -
> -	spin_lock(&glob->lru_lock);
> -	for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
> -		if (list_empty(&man->lru[0]))
> -			pr_debug("Swap list %d was clean\n", i);
> -	spin_unlock(&glob->lru_lock);
> -
> -	ttm_pool_fini(&bdev->pool);
> -
> -	if (!ret)
> -		ttm_bo_global_release();
> -
> -	return ret;
> -}
> -EXPORT_SYMBOL(ttm_bo_device_release);
> -
> -static void ttm_bo_init_sysman(struct ttm_bo_device *bdev)
> -{
> -	struct ttm_resource_manager *man = &bdev->sysman;
> -
> -	/*
> -	 * Initialize the system memory buffer type.
> -	 * Other types need to be driver / IOCTL initialized.
> -	 */
> -	man->use_tt = true;
> -
> -	ttm_resource_manager_init(man, 0);
> -	ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, man);
> -	ttm_resource_manager_set_used(man, true);
> -}
> -
> -int ttm_bo_device_init(struct ttm_bo_device *bdev,
> -		       struct ttm_bo_driver *driver,
> -		       struct device *dev,
> -		       struct address_space *mapping,
> -		       struct drm_vma_offset_manager *vma_manager,
> -		       bool use_dma_alloc, bool use_dma32)
> -{
> -	struct ttm_bo_global *glob = &ttm_bo_glob;
> -	int ret;
> -
> -	if (WARN_ON(vma_manager == NULL))
> -		return -EINVAL;
> -
> -	ret = ttm_bo_global_init();
> -	if (ret)
> -		return ret;
> -
> -	bdev->driver = driver;
> -
> -	ttm_bo_init_sysman(bdev);
> -	ttm_pool_init(&bdev->pool, dev, use_dma_alloc, use_dma32);
> -
> -	bdev->vma_manager = vma_manager;
> -	INIT_DELAYED_WORK(&bdev->wq, ttm_bo_delayed_workqueue);
> -	INIT_LIST_HEAD(&bdev->ddestroy);
> -	bdev->dev_mapping = mapping;
> -	mutex_lock(&ttm_global_mutex);
> -	list_add_tail(&bdev->device_list, &glob->device_list);
> -	mutex_unlock(&ttm_global_mutex);
> -
> -	return 0;
> -}
> -EXPORT_SYMBOL(ttm_bo_device_init);
> -
>  /*
>   * buffer object vm functions.
>   */
>  
>  void ttm_bo_unmap_virtual(struct ttm_buffer_object *bo)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  
>  	drm_vma_node_unmap(&bo->base.vma_node, bdev->dev_mapping);
>  	ttm_mem_io_free(bdev, &bo->mem);
> @@ -1374,7 +1221,7 @@ EXPORT_SYMBOL(ttm_bo_wait);
>   */
>  int ttm_bo_swapout(struct ttm_operation_ctx *ctx)
>  {
> -	struct ttm_bo_global *glob = &ttm_bo_glob;
> +	struct ttm_global *glob = &ttm_glob;
>  	struct ttm_buffer_object *bo;
>  	int ret = -EBUSY;
>  	bool locked;
> @@ -1452,8 +1299,8 @@ int ttm_bo_swapout(struct ttm_operation_ctx *ctx)
>  	 * anyone tries to access a ttm page.
>  	 */
>  
> -	if (bo->bdev->driver->swap_notify)
> -		bo->bdev->driver->swap_notify(bo);
> +	if (bo->bdev->funcs->swap_notify)
> +		bo->bdev->funcs->swap_notify(bo);
>  
>  	ret = ttm_tt_swapout(bo->bdev, bo->ttm);
>  out:
> @@ -1478,4 +1325,3 @@ void ttm_bo_tt_destroy(struct ttm_buffer_object *bo)
>  	ttm_tt_destroy(bo->bdev, bo->ttm);
>  	bo->ttm = NULL;
>  }
> -
> diff --git a/drivers/gpu/drm/ttm/ttm_bo_util.c b/drivers/gpu/drm/ttm/ttm_bo_util.c
> index 398d5013fc39..db0f2661d504 100644
> --- a/drivers/gpu/drm/ttm/ttm_bo_util.c
> +++ b/drivers/gpu/drm/ttm/ttm_bo_util.c
> @@ -46,33 +46,33 @@ struct ttm_transfer_obj {
>  	struct ttm_buffer_object *bo;
>  };
>  
> -int ttm_mem_io_reserve(struct ttm_bo_device *bdev,
> +int ttm_mem_io_reserve(struct ttm_device *bdev,
>  		       struct ttm_resource *mem)
>  {
>  	if (mem->bus.offset || mem->bus.addr)
>  		return 0;
>  
>  	mem->bus.is_iomem = false;
> -	if (!bdev->driver->io_mem_reserve)
> +	if (!bdev->funcs->io_mem_reserve)
>  		return 0;
>  
> -	return bdev->driver->io_mem_reserve(bdev, mem);
> +	return bdev->funcs->io_mem_reserve(bdev, mem);
>  }
>  
> -void ttm_mem_io_free(struct ttm_bo_device *bdev,
> +void ttm_mem_io_free(struct ttm_device *bdev,
>  		     struct ttm_resource *mem)
>  {
>  	if (!mem->bus.offset && !mem->bus.addr)
>  		return;
>  
> -	if (bdev->driver->io_mem_free)
> -		bdev->driver->io_mem_free(bdev, mem);
> +	if (bdev->funcs->io_mem_free)
> +		bdev->funcs->io_mem_free(bdev, mem);
>  
>  	mem->bus.offset = 0;
>  	mem->bus.addr = NULL;
>  }
>  
> -static int ttm_resource_ioremap(struct ttm_bo_device *bdev,
> +static int ttm_resource_ioremap(struct ttm_device *bdev,
>  			       struct ttm_resource *mem,
>  			       void **virtual)
>  {
> @@ -102,7 +102,7 @@ static int ttm_resource_ioremap(struct ttm_bo_device *bdev,
>  	return 0;
>  }
>  
> -static void ttm_resource_iounmap(struct ttm_bo_device *bdev,
> +static void ttm_resource_iounmap(struct ttm_device *bdev,
>  				struct ttm_resource *mem,
>  				void *virtual)
>  {
> @@ -172,7 +172,7 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo,
>  		       struct ttm_operation_ctx *ctx,
>  		       struct ttm_resource *new_mem)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  	struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type);
>  	struct ttm_tt *ttm = bo->ttm;
>  	struct ttm_resource *old_mem = &bo->mem;
> @@ -300,7 +300,7 @@ static int ttm_buffer_object_transfer(struct ttm_buffer_object *bo,
>  	 * TODO: Explicit member copy would probably be better here.
>  	 */
>  
> -	atomic_inc(&ttm_bo_glob.bo_count);
> +	atomic_inc(&ttm_glob.bo_count);
>  	INIT_LIST_HEAD(&fbo->base.ddestroy);
>  	INIT_LIST_HEAD(&fbo->base.lru);
>  	INIT_LIST_HEAD(&fbo->base.swap);
> @@ -602,7 +602,7 @@ static int ttm_bo_move_to_ghost(struct ttm_buffer_object *bo,
>  static void ttm_bo_move_pipeline_evict(struct ttm_buffer_object *bo,
>  				       struct dma_fence *fence)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  	struct ttm_resource_manager *from = ttm_manager_type(bdev, bo->mem.mem_type);
>  
>  	/**
> @@ -628,7 +628,7 @@ int ttm_bo_move_accel_cleanup(struct ttm_buffer_object *bo,
>  			      bool pipeline,
>  			      struct ttm_resource *new_mem)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  	struct ttm_resource_manager *from = ttm_manager_type(bdev, bo->mem.mem_type);
>  	struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type);
>  	int ret = 0;
> diff --git a/drivers/gpu/drm/ttm/ttm_bo_vm.c b/drivers/gpu/drm/ttm/ttm_bo_vm.c
> index 6dc96cf66744..b31b18058965 100644
> --- a/drivers/gpu/drm/ttm/ttm_bo_vm.c
> +++ b/drivers/gpu/drm/ttm/ttm_bo_vm.c
> @@ -95,10 +95,10 @@ static vm_fault_t ttm_bo_vm_fault_idle(struct ttm_buffer_object *bo,
>  static unsigned long ttm_bo_io_mem_pfn(struct ttm_buffer_object *bo,
>  				       unsigned long page_offset)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  
> -	if (bdev->driver->io_mem_pfn)
> -		return bdev->driver->io_mem_pfn(bo, page_offset);
> +	if (bdev->funcs->io_mem_pfn)
> +		return bdev->funcs->io_mem_pfn(bo, page_offset);
>  
>  	return (bo->mem.bus.offset >> PAGE_SHIFT) + page_offset;
>  }
> @@ -216,7 +216,7 @@ static vm_fault_t ttm_bo_vm_insert_huge(struct vm_fault *vmf,
>  			if (page_to_pfn(ttm->pages[page_offset + i]) != pfn + i)
>  				goto out_fallback;
>  		}
> -	} else if (bo->bdev->driver->io_mem_pfn) {
> +	} else if (bo->bdev->funcs->io_mem_pfn) {
>  		for (i = 1; i < fault_page_size; ++i) {
>  			if (ttm_bo_io_mem_pfn(bo, page_offset + i) != pfn + i)
>  				goto out_fallback;
> @@ -278,7 +278,7 @@ vm_fault_t ttm_bo_vm_fault_reserved(struct vm_fault *vmf,
>  {
>  	struct vm_area_struct *vma = vmf->vma;
>  	struct ttm_buffer_object *bo = vma->vm_private_data;
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  	unsigned long page_offset;
>  	unsigned long page_last;
>  	unsigned long pfn;
> @@ -488,8 +488,8 @@ int ttm_bo_vm_access(struct vm_area_struct *vma, unsigned long addr,
>  		ret = ttm_bo_vm_access_kmap(bo, offset, buf, len, write);
>  		break;
>  	default:
> -		if (bo->bdev->driver->access_memory)
> -			ret = bo->bdev->driver->access_memory(
> +		if (bo->bdev->funcs->access_memory)
> +			ret = bo->bdev->funcs->access_memory(
>  				bo, offset, buf, len, write);
>  		else
>  			ret = -EIO;
> @@ -508,7 +508,7 @@ static const struct vm_operations_struct ttm_bo_vm_ops = {
>  	.access = ttm_bo_vm_access,
>  };
>  
> -static struct ttm_buffer_object *ttm_bo_vm_lookup(struct ttm_bo_device *bdev,
> +static struct ttm_buffer_object *ttm_bo_vm_lookup(struct ttm_device *bdev,
>  						  unsigned long offset,
>  						  unsigned long pages)
>  {
> @@ -555,9 +555,8 @@ static void ttm_bo_mmap_vma_setup(struct ttm_buffer_object *bo, struct vm_area_s
>  }
>  
>  int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
> -		struct ttm_bo_device *bdev)
> +		struct ttm_device *bdev)
>  {
> -	struct ttm_bo_driver *driver;
>  	struct ttm_buffer_object *bo;
>  	int ret;
>  
> @@ -568,12 +567,11 @@ int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
>  	if (unlikely(!bo))
>  		return -EINVAL;
>  
> -	driver = bo->bdev->driver;
> -	if (unlikely(!driver->verify_access)) {
> +	if (unlikely(!bo->bdev->funcs->verify_access)) {
>  		ret = -EPERM;
>  		goto out_unref;
>  	}
> -	ret = driver->verify_access(bo, filp);
> +	ret = bo->bdev->funcs->verify_access(bo, filp);
>  	if (unlikely(ret != 0))
>  		goto out_unref;
>  
> diff --git a/drivers/gpu/drm/ttm/ttm_device.c b/drivers/gpu/drm/ttm/ttm_device.c
> new file mode 100644
> index 000000000000..ac0903c9e60a
> --- /dev/null
> +++ b/drivers/gpu/drm/ttm/ttm_device.c
> @@ -0,0 +1,195 @@
> +/* SPDX-License-Identifier: GPL-2.0 OR MIT */
> +
> +/*
> + * Copyright (c) 2006-2009 VMware, Inc., Palo Alto, CA., USA
> + * Copyright 2020 Advanced Micro Devices, Inc.
> + *
> + * Permission is hereby granted, free of charge, to any person obtaining a
> + * copy of this software and associated documentation files (the "Software"),
> + * to deal in the Software without restriction, including without limitation
> + * the rights to use, copy, modify, merge, publish, distribute, sublicense,
> + * and/or sell copies of the Software, and to permit persons to whom the
> + * Software is furnished to do so, subject to the following conditions:
> + *
> + * The above copyright notice and this permission notice shall be included in
> + * all copies or substantial portions of the Software.
> + *
> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
> + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
> + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
> + * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
> + * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
> + * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
> + * OTHER DEALINGS IN THE SOFTWARE.
> + *
> + * Authors: Christian König
> + */
> +
> +#define pr_fmt(fmt) "[TTM DEVICE] " fmt
> +
> +#include <drm/ttm/ttm_device.h>
> +#include <drm/ttm/ttm_memory.h>
> +#include <drm/ttm/ttm_placement.h>
> +
> +#include "ttm_module.h"
> +
> +/**
> + * ttm_global_mutex - protecting the global state
> + */
> +DEFINE_MUTEX(ttm_global_mutex);
> +unsigned ttm_glob_use_count;
> +struct ttm_global ttm_glob;
> +EXPORT_SYMBOL(ttm_glob);
> +
> +static void ttm_global_release(void)
> +{
> +	struct ttm_global *glob = &ttm_glob;
> +
> +	mutex_lock(&ttm_global_mutex);
> +	if (--ttm_glob_use_count > 0)
> +		goto out;
> +
> +	kobject_del(&glob->kobj);
> +	kobject_put(&glob->kobj);
> +	ttm_mem_global_release(&ttm_mem_glob);
> +	__free_page(glob->dummy_read_page);
> +	memset(glob, 0, sizeof(*glob));
> +out:
> +	mutex_unlock(&ttm_global_mutex);
> +}
> +
> +static int ttm_global_init(void)
> +{
> +	struct ttm_global *glob = &ttm_glob;
> +	int ret = 0;
> +	unsigned i;
> +
> +	mutex_lock(&ttm_global_mutex);
> +	if (++ttm_glob_use_count > 1)
> +		goto out;
> +
> +	ret = ttm_mem_global_init(&ttm_mem_glob);
> +	if (ret)
> +		goto out;
> +
> +	spin_lock_init(&glob->lru_lock);
> +	glob->dummy_read_page = alloc_page(__GFP_ZERO | GFP_DMA32);
> +
> +	if (unlikely(glob->dummy_read_page == NULL)) {
> +		ret = -ENOMEM;
> +		goto out;
> +	}
> +
> +	for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
> +		INIT_LIST_HEAD(&glob->swap_lru[i]);
> +	INIT_LIST_HEAD(&glob->device_list);
> +	atomic_set(&glob->bo_count, 0);
> +
> +	debugfs_create_atomic_t("buffer_objects", 0444, ttm_debugfs_root,
> +				&glob->bo_count);
> +out:
> +	mutex_unlock(&ttm_global_mutex);
> +	return ret;
> +}
> +
> +static void ttm_init_sysman(struct ttm_device *bdev)
> +{
> +	struct ttm_resource_manager *man = &bdev->sysman;
> +
> +	/*
> +	 * Initialize the system memory buffer type.
> +	 * Other types need to be driver / IOCTL initialized.
> +	 */
> +	man->use_tt = true;
> +
> +	ttm_resource_manager_init(man, 0);
> +	ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, man);
> +	ttm_resource_manager_set_used(man, true);
> +}
> +
> +static void ttm_device_delayed_workqueue(struct work_struct *work)
> +{
> +	struct ttm_device *bdev =
> +		container_of(work, struct ttm_device, wq.work);
> +
> +	if (!ttm_bo_delayed_delete(bdev, false))
> +		schedule_delayed_work(&bdev->wq,
> +				      ((HZ / 100) < 1) ? 1 : HZ / 100);
> +}
> +
> +/**
> + * ttm_device_init
> + *
> + * @bdev: A pointer to a struct ttm_device to initialize.
> + * @funcs: Function table for the device.
> + * @dev: The core kernel device pointer for DMA mappings and allocations.
> + * @mapping: The address space to use for this bo.
> + * @vma_manager: A pointer to a vma manager.
> + * @use_dma_alloc: If coherent DMA allocation API should be used.
> + * @use_dma32: If we should use GFP_DMA32 for device memory allocations.
> + *
> + * Initializes a struct ttm_device:
> + * Returns:
> + * !0: Failure.
> + */
> +int ttm_device_init(struct ttm_device *bdev, struct ttm_device_funcs *funcs,
> +		    struct device *dev, struct address_space *mapping,
> +		    struct drm_vma_offset_manager *vma_manager,
> +		    bool use_dma_alloc, bool use_dma32)
> +{
> +	struct ttm_global *glob = &ttm_glob;
> +	int ret;
> +
> +	if (WARN_ON(vma_manager == NULL))
> +		return -EINVAL;
> +
> +	ret = ttm_global_init();
> +	if (ret)
> +		return ret;
> +
> +	bdev->funcs = funcs;
> +
> +	ttm_init_sysman(bdev);
> +	ttm_pool_init(&bdev->pool, dev, use_dma_alloc, use_dma32);
> +
> +	bdev->vma_manager = vma_manager;
> +	INIT_DELAYED_WORK(&bdev->wq, ttm_device_delayed_workqueue);
> +	INIT_LIST_HEAD(&bdev->ddestroy);
> +	bdev->dev_mapping = mapping;
> +	mutex_lock(&ttm_global_mutex);
> +	list_add_tail(&bdev->device_list, &glob->device_list);
> +	mutex_unlock(&ttm_global_mutex);
> +
> +	return 0;
> +}
> +EXPORT_SYMBOL(ttm_device_init);
> +
> +void ttm_device_fini(struct ttm_device *bdev)
> +{
> +	struct ttm_global *glob = &ttm_glob;
> +	struct ttm_resource_manager *man;
> +	unsigned i;
> +
> +	man = ttm_manager_type(bdev, TTM_PL_SYSTEM);
> +	ttm_resource_manager_set_used(man, false);
> +	ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, NULL);
> +
> +	mutex_lock(&ttm_global_mutex);
> +	list_del(&bdev->device_list);
> +	mutex_unlock(&ttm_global_mutex);
> +
> +	cancel_delayed_work_sync(&bdev->wq);
> +
> +	if (ttm_bo_delayed_delete(bdev, true))
> +		pr_debug("Delayed destroy list was clean\n");
> +
> +	spin_lock(&glob->lru_lock);
> +	for (i = 0; i < TTM_MAX_BO_PRIORITY; ++i)
> +		if (list_empty(&man->lru[0]))
> +			pr_debug("Swap list %d was clean\n", i);
> +	spin_unlock(&glob->lru_lock);
> +
> +	ttm_pool_fini(&bdev->pool);
> +	ttm_global_release();
> +}
> +EXPORT_SYMBOL(ttm_device_fini);
> diff --git a/drivers/gpu/drm/ttm/ttm_execbuf_util.c b/drivers/gpu/drm/ttm/ttm_execbuf_util.c
> index 9fa36ed59429..690ab97d52b7 100644
> --- a/drivers/gpu/drm/ttm/ttm_execbuf_util.c
> +++ b/drivers/gpu/drm/ttm/ttm_execbuf_util.c
> @@ -51,14 +51,14 @@ void ttm_eu_backoff_reservation(struct ww_acquire_ctx *ticket,
>  	if (list_empty(list))
>  		return;
>  
> -	spin_lock(&ttm_bo_glob.lru_lock);
> +	spin_lock(&ttm_glob.lru_lock);
>  	list_for_each_entry(entry, list, head) {
>  		struct ttm_buffer_object *bo = entry->bo;
>  
>  		ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
>  		dma_resv_unlock(bo->base.resv);
>  	}
> -	spin_unlock(&ttm_bo_glob.lru_lock);
> +	spin_unlock(&ttm_glob.lru_lock);
>  
>  	if (ticket)
>  		ww_acquire_fini(ticket);
> @@ -154,7 +154,7 @@ void ttm_eu_fence_buffer_objects(struct ww_acquire_ctx *ticket,
>  	if (list_empty(list))
>  		return;
>  
> -	spin_lock(&ttm_bo_glob.lru_lock);
> +	spin_lock(&ttm_glob.lru_lock);
>  	list_for_each_entry(entry, list, head) {
>  		struct ttm_buffer_object *bo = entry->bo;
>  
> @@ -165,7 +165,7 @@ void ttm_eu_fence_buffer_objects(struct ww_acquire_ctx *ticket,
>  		ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
>  		dma_resv_unlock(bo->base.resv);
>  	}
> -	spin_unlock(&ttm_bo_glob.lru_lock);
> +	spin_unlock(&ttm_glob.lru_lock);
>  	if (ticket)
>  		ww_acquire_fini(ticket);
>  }
> diff --git a/drivers/gpu/drm/ttm/ttm_range_manager.c b/drivers/gpu/drm/ttm/ttm_range_manager.c
> index a39305f742da..707e5c152896 100644
> --- a/drivers/gpu/drm/ttm/ttm_range_manager.c
> +++ b/drivers/gpu/drm/ttm/ttm_range_manager.c
> @@ -111,7 +111,7 @@ static void ttm_range_man_free(struct ttm_resource_manager *man,
>  
>  static const struct ttm_resource_manager_func ttm_range_manager_func;
>  
> -int ttm_range_man_init(struct ttm_bo_device *bdev,
> +int ttm_range_man_init(struct ttm_device *bdev,
>  		       unsigned type, bool use_tt,
>  		       unsigned long p_size)
>  {
> @@ -138,7 +138,7 @@ int ttm_range_man_init(struct ttm_bo_device *bdev,
>  }
>  EXPORT_SYMBOL(ttm_range_man_init);
>  
> -int ttm_range_man_fini(struct ttm_bo_device *bdev,
> +int ttm_range_man_fini(struct ttm_device *bdev,
>  		       unsigned type)
>  {
>  	struct ttm_resource_manager *man = ttm_manager_type(bdev, type);
> diff --git a/drivers/gpu/drm/ttm/ttm_resource.c b/drivers/gpu/drm/ttm/ttm_resource.c
> index b60699bf4816..ed1672a9f332 100644
> --- a/drivers/gpu/drm/ttm/ttm_resource.c
> +++ b/drivers/gpu/drm/ttm/ttm_resource.c
> @@ -83,7 +83,7 @@ EXPORT_SYMBOL(ttm_resource_manager_init);
>   * Evict all the objects out of a memory manager until it is empty.
>   * Part of memory manager cleanup sequence.
>   */
> -int ttm_resource_manager_evict_all(struct ttm_bo_device *bdev,
> +int ttm_resource_manager_evict_all(struct ttm_device *bdev,
>  				   struct ttm_resource_manager *man)
>  {
>  	struct ttm_operation_ctx ctx = {
> @@ -91,7 +91,7 @@ int ttm_resource_manager_evict_all(struct ttm_bo_device *bdev,
>  		.no_wait_gpu = false,
>  		.force_alloc = true
>  	};
> -	struct ttm_bo_global *glob = &ttm_bo_glob;
> +	struct ttm_global *glob = &ttm_glob;
>  	struct dma_fence *fence;
>  	int ret;
>  	unsigned i;
> diff --git a/drivers/gpu/drm/ttm/ttm_tt.c b/drivers/gpu/drm/ttm/ttm_tt.c
> index 7f75a13163f0..7782d5393c7c 100644
> --- a/drivers/gpu/drm/ttm/ttm_tt.c
> +++ b/drivers/gpu/drm/ttm/ttm_tt.c
> @@ -43,7 +43,7 @@
>   */
>  int ttm_tt_create(struct ttm_buffer_object *bo, bool zero_alloc)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  	uint32_t page_flags = 0;
>  
>  	dma_resv_assert_held(bo->base.resv);
> @@ -66,7 +66,7 @@ int ttm_tt_create(struct ttm_buffer_object *bo, bool zero_alloc)
>  		return -EINVAL;
>  	}
>  
> -	bo->ttm = bdev->driver->ttm_tt_create(bo, page_flags);
> +	bo->ttm = bdev->funcs->ttm_tt_create(bo, page_flags);
>  	if (unlikely(bo->ttm == NULL))
>  		return -ENOMEM;
>  
> @@ -108,7 +108,7 @@ static int ttm_sg_tt_alloc_page_directory(struct ttm_tt *ttm)
>  	return 0;
>  }
>  
> -void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +void ttm_tt_destroy_common(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  	ttm_tt_unpopulate(bdev, ttm);
>  
> @@ -119,9 +119,9 @@ void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>  }
>  EXPORT_SYMBOL(ttm_tt_destroy_common);
>  
> -void ttm_tt_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +void ttm_tt_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
> -	bdev->driver->ttm_tt_destroy(bdev, ttm);
> +	bdev->funcs->ttm_tt_destroy(bdev, ttm);
>  }
>  
>  static void ttm_tt_init_fields(struct ttm_tt *ttm,
> @@ -223,7 +223,7 @@ int ttm_tt_swapin(struct ttm_tt *ttm)
>  	return ret;
>  }
>  
> -int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +int ttm_tt_swapout(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  	struct address_space *swap_space;
>  	struct file *swap_storage;
> @@ -271,7 +271,7 @@ int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>  	return ret;
>  }
>  
> -static void ttm_tt_add_mapping(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static void ttm_tt_add_mapping(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  	pgoff_t i;
>  
> @@ -282,7 +282,7 @@ static void ttm_tt_add_mapping(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>  		ttm->pages[i]->mapping = bdev->dev_mapping;
>  }
>  
> -int ttm_tt_populate(struct ttm_bo_device *bdev,
> +int ttm_tt_populate(struct ttm_device *bdev,
>  		    struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)
>  {
>  	int ret;
> @@ -293,8 +293,8 @@ int ttm_tt_populate(struct ttm_bo_device *bdev,
>  	if (ttm_tt_is_populated(ttm))
>  		return 0;
>  
> -	if (bdev->driver->ttm_tt_populate)
> -		ret = bdev->driver->ttm_tt_populate(bdev, ttm, ctx);
> +	if (bdev->funcs->ttm_tt_populate)
> +		ret = bdev->funcs->ttm_tt_populate(bdev, ttm, ctx);
>  	else
>  		ret = ttm_pool_alloc(&bdev->pool, ttm, ctx);
>  	if (ret)
> @@ -328,15 +328,15 @@ static void ttm_tt_clear_mapping(struct ttm_tt *ttm)
>  	}
>  }
>  
> -void ttm_tt_unpopulate(struct ttm_bo_device *bdev,
> +void ttm_tt_unpopulate(struct ttm_device *bdev,
>  		       struct ttm_tt *ttm)
>  {
>  	if (!ttm_tt_is_populated(ttm))
>  		return;
>  
>  	ttm_tt_clear_mapping(ttm);
> -	if (bdev->driver->ttm_tt_unpopulate)
> -		bdev->driver->ttm_tt_unpopulate(bdev, ttm);
> +	if (bdev->funcs->ttm_tt_unpopulate)
> +		bdev->funcs->ttm_tt_unpopulate(bdev, ttm);
>  	else
>  		ttm_pool_free(&bdev->pool, ttm);
>  	ttm->page_flags &= ~TTM_PAGE_FLAG_PRIV_POPULATED;
> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c b/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c
> index 118db24eb756..3a438ae4d3f4 100644
> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c
> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_blit.c
> @@ -466,13 +466,13 @@ int vmw_bo_cpu_blit(struct ttm_buffer_object *dst,
>  		dma_resv_assert_held(src->base.resv);
>  
>  	if (!ttm_tt_is_populated(dst->ttm)) {
> -		ret = dst->bdev->driver->ttm_tt_populate(dst->bdev, dst->ttm, &ctx);
> +		ret = dst->bdev->funcs->ttm_tt_populate(dst->bdev, dst->ttm, &ctx);
>  		if (ret)
>  			return ret;
>  	}
>  
>  	if (!ttm_tt_is_populated(src->ttm)) {
> -		ret = src->bdev->driver->ttm_tt_populate(src->bdev, src->ttm, &ctx);
> +		ret = src->bdev->funcs->ttm_tt_populate(src->bdev, src->ttm, &ctx);
>  		if (ret)
>  			return ret;
>  	}
> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c b/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
> index ab0844b47d4d..6b3bfd8c678a 100644
> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
> @@ -545,7 +545,7 @@ int vmw_bo_init(struct vmw_private *dev_priv,
>  		void (*bo_free)(struct ttm_buffer_object *bo))
>  {
>  	struct ttm_operation_ctx ctx = { interruptible, false };
> -	struct ttm_bo_device *bdev = &dev_priv->bdev;
> +	struct ttm_device *bdev = &dev_priv->bdev;
>  	size_t acc_size;
>  	int ret;
>  	bool user = (bo_free == &vmw_user_bo_destroy);
> @@ -1058,7 +1058,7 @@ int vmw_user_bo_reference(struct ttm_object_file *tfile,
>  void vmw_bo_fence_single(struct ttm_buffer_object *bo,
>  			 struct vmw_fence_obj *fence)
>  {
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  
>  	struct vmw_private *dev_priv =
>  		container_of(bdev, struct vmw_private, bdev);
> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
> index eb997f4678de..b454d80c273e 100644
> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
> @@ -884,12 +884,12 @@ static int vmw_driver_load(struct vmw_private *dev_priv, u32 pci_id)
>  	drm_vma_offset_manager_init(&dev_priv->vma_manager,
>  				    DRM_FILE_PAGE_OFFSET_START,
>  				    DRM_FILE_PAGE_OFFSET_SIZE);
> -	ret = ttm_bo_device_init(&dev_priv->bdev, &vmw_bo_driver,
> -				 dev_priv->drm.dev,
> -				 dev_priv->drm.anon_inode->i_mapping,
> -				 &dev_priv->vma_manager,
> -				 dev_priv->map_mode == vmw_dma_alloc_coherent,
> -				 false);
> +	ret = ttm_device_init(&dev_priv->bdev, &vmw_bo_driver,
> +			      dev_priv->drm.dev,
> +			      dev_priv->drm.anon_inode->i_mapping,
> +			      &dev_priv->vma_manager,
> +			      dev_priv->map_mode == vmw_dma_alloc_coherent,
> +			      false);
>  	if (unlikely(ret != 0)) {
>  		DRM_ERROR("Failed initializing TTM buffer object driver.\n");
>  		goto out_no_bdev;
> @@ -1006,7 +1006,7 @@ static int vmw_driver_load(struct vmw_private *dev_priv, u32 pci_id)
>  		vmw_gmrid_man_fini(dev_priv, VMW_PL_GMR);
>  	vmw_vram_manager_fini(dev_priv);
>  out_no_vram:
> -	(void)ttm_bo_device_release(&dev_priv->bdev);
> +	ttm_device_fini(&dev_priv->bdev);
>  out_no_bdev:
>  	vmw_fence_manager_takedown(dev_priv->fman);
>  out_no_fman:
> @@ -1053,7 +1053,7 @@ static void vmw_driver_unload(struct drm_device *dev)
>  	if (dev_priv->has_mob)
>  		vmw_gmrid_man_fini(dev_priv, VMW_PL_MOB);
>  	vmw_vram_manager_fini(dev_priv);
> -	(void) ttm_bo_device_release(&dev_priv->bdev);
> +	ttm_device_fini(&dev_priv->bdev);
>  	drm_vma_offset_manager_destroy(&dev_priv->vma_manager);
>  	vmw_release_device_late(dev_priv);
>  	vmw_fence_manager_takedown(dev_priv->fman);
> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
> index 336f5086ca26..e65b00f8336d 100644
> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
> @@ -484,7 +484,7 @@ enum vmw_sm_type {
>  
>  struct vmw_private {
>  	struct drm_device drm;
> -	struct ttm_bo_device bdev;
> +	struct ttm_device bdev;
>  
>  	struct vmw_fifo_state fifo;
>  
> @@ -999,7 +999,7 @@ extern struct ttm_placement vmw_evictable_placement;
>  extern struct ttm_placement vmw_srf_placement;
>  extern struct ttm_placement vmw_mob_placement;
>  extern struct ttm_placement vmw_nonfixed_placement;
> -extern struct ttm_bo_driver vmw_bo_driver;
> +extern struct ttm_device_funcs vmw_bo_driver;
>  extern const struct vmw_sg_table *
>  vmw_bo_sg_table(struct ttm_buffer_object *bo);
>  extern int vmw_bo_create_and_populate(struct vmw_private *dev_priv,
> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c b/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c
> index c4df51a2a926..c3a724e37104 100644
> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c
> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_resource.c
> @@ -856,7 +856,7 @@ void vmw_query_move_notify(struct ttm_buffer_object *bo,
>  			   struct ttm_resource *mem)
>  {
>  	struct vmw_buffer_object *dx_query_mob;
> -	struct ttm_bo_device *bdev = bo->bdev;
> +	struct ttm_device *bdev = bo->bdev;
>  	struct vmw_private *dev_priv;
>  
>  
> diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c b/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c
> index 6a44567e4ba5..d1bfa59579f1 100644
> --- a/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c
> +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c
> @@ -483,7 +483,7 @@ const struct vmw_sg_table *vmw_bo_sg_table(struct ttm_buffer_object *bo)
>  }
>  
>  
> -static int vmw_ttm_bind(struct ttm_bo_device *bdev,
> +static int vmw_ttm_bind(struct ttm_device *bdev,
>  			struct ttm_tt *ttm, struct ttm_resource *bo_mem)
>  {
>  	struct vmw_ttm_tt *vmw_be =
> @@ -527,7 +527,7 @@ static int vmw_ttm_bind(struct ttm_bo_device *bdev,
>  	return ret;
>  }
>  
> -static void vmw_ttm_unbind(struct ttm_bo_device *bdev,
> +static void vmw_ttm_unbind(struct ttm_device *bdev,
>  			   struct ttm_tt *ttm)
>  {
>  	struct vmw_ttm_tt *vmw_be =
> @@ -553,7 +553,7 @@ static void vmw_ttm_unbind(struct ttm_bo_device *bdev,
>  }
>  
>  
> -static void vmw_ttm_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
> +static void vmw_ttm_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)
>  {
>  	struct vmw_ttm_tt *vmw_be =
>  		container_of(ttm, struct vmw_ttm_tt, dma_ttm);
> @@ -573,7 +573,7 @@ static void vmw_ttm_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm)
>  }
>  
>  
> -static int vmw_ttm_populate(struct ttm_bo_device *bdev,
> +static int vmw_ttm_populate(struct ttm_device *bdev,
>  			    struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)
>  {
>  	/* TODO: maybe completely drop this ? */
> @@ -583,7 +583,7 @@ static int vmw_ttm_populate(struct ttm_bo_device *bdev,
>  	return ttm_pool_alloc(&bdev->pool, ttm, ctx);
>  }
>  
> -static void vmw_ttm_unpopulate(struct ttm_bo_device *bdev,
> +static void vmw_ttm_unpopulate(struct ttm_device *bdev,
>  			       struct ttm_tt *ttm)
>  {
>  	struct vmw_ttm_tt *vmw_tt = container_of(ttm, struct vmw_ttm_tt,
> @@ -640,7 +640,7 @@ static int vmw_verify_access(struct ttm_buffer_object *bo, struct file *filp)
>  	return vmw_user_bo_verify_access(bo, tfile);
>  }
>  
> -static int vmw_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_resource *mem)
> +static int vmw_ttm_io_mem_reserve(struct ttm_device *bdev, struct ttm_resource *mem)
>  {
>  	struct vmw_private *dev_priv = container_of(bdev, struct vmw_private, bdev);
>  
> @@ -744,7 +744,7 @@ vmw_delete_mem_notify(struct ttm_buffer_object *bo)
>  	vmw_move_notify(bo, false, NULL);
>  }
>  
> -struct ttm_bo_driver vmw_bo_driver = {
> +struct ttm_device_funcs vmw_bo_driver = {
>  	.ttm_tt_create = &vmw_ttm_tt_create,
>  	.ttm_tt_populate = &vmw_ttm_populate,
>  	.ttm_tt_unpopulate = &vmw_ttm_unpopulate,
> diff --git a/include/drm/drm_gem_vram_helper.h b/include/drm/drm_gem_vram_helper.h
> index a4bac02249c2..288055d397d9 100644
> --- a/include/drm/drm_gem_vram_helper.h
> +++ b/include/drm/drm_gem_vram_helper.h
> @@ -172,19 +172,19 @@ struct drm_vram_mm {
>  	uint64_t vram_base;
>  	size_t vram_size;
>  
> -	struct ttm_bo_device bdev;
> +	struct ttm_device bdev;
>  };
>  
>  /**
>   * drm_vram_mm_of_bdev() - \
> -	Returns the container of type &struct ttm_bo_device for field bdev.
> +	Returns the container of type &struct ttm_device for field bdev.
>   * @bdev:	the TTM BO device
>   *
>   * Returns:
>   * The containing instance of &struct drm_vram_mm
>   */
>  static inline struct drm_vram_mm *drm_vram_mm_of_bdev(
> -	struct ttm_bo_device *bdev)
> +	struct ttm_device *bdev)
>  {
>  	return container_of(bdev, struct drm_vram_mm, bdev);
>  }
> diff --git a/include/drm/ttm/ttm_bo_api.h b/include/drm/ttm/ttm_bo_api.h
> index e17be324d95f..62734db0b421 100644
> --- a/include/drm/ttm/ttm_bo_api.h
> +++ b/include/drm/ttm/ttm_bo_api.h
> @@ -44,9 +44,9 @@
>  
>  #include "ttm_resource.h"
>  
> -struct ttm_bo_global;
> +struct ttm_global;
>  
> -struct ttm_bo_device;
> +struct ttm_device;
>  
>  struct dma_buf_map;
>  
> @@ -122,7 +122,7 @@ struct ttm_buffer_object {
>  	 * Members constant at init.
>  	 */
>  
> -	struct ttm_bo_device *bdev;
> +	struct ttm_device *bdev;
>  	enum ttm_bo_type type;
>  	void (*destroy) (struct ttm_buffer_object *);
>  	size_t acc_size;
> @@ -313,7 +313,7 @@ void ttm_bo_put(struct ttm_buffer_object *bo);
>   * @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
> + * object. This function must be called with struct ttm_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,
> @@ -326,7 +326,7 @@ void ttm_bo_move_to_lru_tail(struct ttm_buffer_object *bo,
>   * @bulk: bulk move structure
>   *
>   * Bulk move BOs to the LRU tail, only valid to use when driver makes sure that
> - * BO order never changes. Should be called with ttm_bo_global::lru_lock held.
> + * BO order never changes. Should be called with ttm_global::lru_lock held.
>   */
>  void ttm_bo_bulk_move_lru_tail(struct ttm_lru_bulk_move *bulk);
>  
> @@ -337,14 +337,14 @@ void ttm_bo_bulk_move_lru_tail(struct ttm_lru_bulk_move *bulk);
>   * Returns
>   * True if the workqueue was queued at the time
>   */
> -int ttm_bo_lock_delayed_workqueue(struct ttm_bo_device *bdev);
> +int ttm_bo_lock_delayed_workqueue(struct ttm_device *bdev);
>  
>  /**
>   * ttm_bo_unlock_delayed_workqueue
>   *
>   * Allows the delayed workqueue to run.
>   */
> -void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev, int resched);
> +void ttm_bo_unlock_delayed_workqueue(struct ttm_device *bdev, int resched);
>  
>  /**
>   * ttm_bo_eviction_valuable
> @@ -357,14 +357,14 @@ void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev, int resched);
>  bool ttm_bo_eviction_valuable(struct ttm_buffer_object *bo,
>  			      const struct ttm_place *place);
>  
> -size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
> +size_t ttm_bo_dma_acc_size(struct ttm_device *bdev,
>  			   unsigned long bo_size,
>  			   unsigned struct_size);
>  
>  /**
>   * ttm_bo_init_reserved
>   *
> - * @bdev: Pointer to a ttm_bo_device struct.
> + * @bdev: Pointer to a ttm_device struct.
>   * @bo: Pointer to a ttm_buffer_object to be initialized.
>   * @size: Requested size of buffer object.
>   * @type: Requested type of buffer object.
> @@ -396,7 +396,7 @@ size_t ttm_bo_dma_acc_size(struct ttm_bo_device *bdev,
>   * -ERESTARTSYS: Interrupted by signal while sleeping waiting for resources.
>   */
>  
> -int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
> +int ttm_bo_init_reserved(struct ttm_device *bdev,
>  			 struct ttm_buffer_object *bo,
>  			 size_t size, enum ttm_bo_type type,
>  			 struct ttm_placement *placement,
> @@ -409,7 +409,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>  /**
>   * ttm_bo_init
>   *
> - * @bdev: Pointer to a ttm_bo_device struct.
> + * @bdev: Pointer to a ttm_device struct.
>   * @bo: Pointer to a ttm_buffer_object to be initialized.
>   * @size: Requested size of buffer object.
>   * @type: Requested type of buffer object.
> @@ -443,7 +443,7 @@ int ttm_bo_init_reserved(struct ttm_bo_device *bdev,
>   * -EINVAL: Invalid placement flags.
>   * -ERESTARTSYS: Interrupted by signal while sleeping waiting for resources.
>   */
> -int ttm_bo_init(struct ttm_bo_device *bdev, struct ttm_buffer_object *bo,
> +int ttm_bo_init(struct ttm_device *bdev, struct ttm_buffer_object *bo,
>  		size_t size, enum ttm_bo_type type,
>  		struct ttm_placement *placement,
>  		uint32_t page_alignment, bool interrubtible, size_t acc_size,
> @@ -537,18 +537,18 @@ int ttm_bo_mmap_obj(struct vm_area_struct *vma, struct ttm_buffer_object *bo);
>   *
>   * @filp:      filp as input from the mmap method.
>   * @vma:       vma as input from the mmap method.
> - * @bdev:      Pointer to the ttm_bo_device with the address space manager.
> + * @bdev:      Pointer to the ttm_device with the address space manager.
>   *
>   * This function is intended to be called by the device mmap method.
>   * if the device address space is to be backed by the bo manager.
>   */
>  int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
> -		struct ttm_bo_device *bdev);
> +		struct ttm_device *bdev);
>  
>  /**
>   * ttm_bo_io
>   *
> - * @bdev:      Pointer to the struct ttm_bo_device.
> + * @bdev:      Pointer to the struct ttm_device.
>   * @filp:      Pointer to the struct file attempting to read / write.
>   * @wbuf:      User-space pointer to address of buffer to write. NULL on read.
>   * @rbuf:      User-space pointer to address of buffer to read into.
> @@ -565,7 +565,7 @@ int ttm_bo_mmap(struct file *filp, struct vm_area_struct *vma,
>   * the function may return -ERESTARTSYS if
>   * interrupted by a signal.
>   */
> -ssize_t ttm_bo_io(struct ttm_bo_device *bdev, struct file *filp,
> +ssize_t ttm_bo_io(struct ttm_device *bdev, struct file *filp,
>  		  const char __user *wbuf, char __user *rbuf,
>  		  size_t count, loff_t *f_pos, bool write);
>  
> @@ -617,7 +617,7 @@ static inline void ttm_bo_unpin(struct ttm_buffer_object *bo)
>  	--bo->pin_count;
>  }
>  
> -int ttm_mem_evict_first(struct ttm_bo_device *bdev,
> +int ttm_mem_evict_first(struct ttm_device *bdev,
>  			struct ttm_resource_manager *man,
>  			const struct ttm_place *place,
>  			struct ttm_operation_ctx *ctx,
> @@ -642,5 +642,6 @@ void ttm_bo_vm_close(struct vm_area_struct *vma);
>  
>  int ttm_bo_vm_access(struct vm_area_struct *vma, unsigned long addr,
>  		     void *buf, int len, int write);
> +bool ttm_bo_delayed_delete(struct ttm_device *bdev, bool remove_all);
>  
>  #endif
> diff --git a/include/drm/ttm/ttm_bo_driver.h b/include/drm/ttm/ttm_bo_driver.h
> index 423348414c59..1c9bf993e252 100644
> --- a/include/drm/ttm/ttm_bo_driver.h
> +++ b/include/drm/ttm/ttm_bo_driver.h
> @@ -37,301 +37,14 @@
>  #include <linux/spinlock.h>
>  #include <linux/dma-resv.h>
>  
> +#include <drm/ttm/ttm_device.h>
> +
>  #include "ttm_bo_api.h"
>  #include "ttm_memory.h"
>  #include "ttm_placement.h"
>  #include "ttm_tt.h"
>  #include "ttm_pool.h"
>  
> -/**
> - * struct ttm_bo_driver
> - *
> - * @create_ttm_backend_entry: Callback to create a struct ttm_backend.
> - * @evict_flags: Callback to obtain placement flags when a buffer is evicted.
> - * @move: Callback for a driver to hook in accelerated functions to
> - * move a buffer.
> - * If set to NULL, a potentially slow memcpy() move is used.
> - */
> -
> -struct ttm_bo_driver {
> -	/**
> -	 * ttm_tt_create
> -	 *
> -	 * @bo: The buffer object to create the ttm for.
> -	 * @page_flags: Page flags as identified by TTM_PAGE_FLAG_XX flags.
> -	 *
> -	 * Create a struct ttm_tt to back data with system memory pages.
> -	 * No pages are actually allocated.
> -	 * Returns:
> -	 * NULL: Out of memory.
> -	 */
> -	struct ttm_tt *(*ttm_tt_create)(struct ttm_buffer_object *bo,
> -					uint32_t page_flags);
> -
> -	/**
> -	 * ttm_tt_populate
> -	 *
> -	 * @ttm: The struct ttm_tt to contain the backing pages.
> -	 *
> -	 * Allocate all backing pages
> -	 * Returns:
> -	 * -ENOMEM: Out of memory.
> -	 */
> -	int (*ttm_tt_populate)(struct ttm_bo_device *bdev,
> -			       struct ttm_tt *ttm,
> -			       struct ttm_operation_ctx *ctx);
> -
> -	/**
> -	 * ttm_tt_unpopulate
> -	 *
> -	 * @ttm: The struct ttm_tt to contain the backing pages.
> -	 *
> -	 * Free all backing page
> -	 */
> -	void (*ttm_tt_unpopulate)(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> -
> -	/**
> -	 * ttm_tt_destroy
> -	 *
> -	 * @bdev: Pointer to a ttm device
> -	 * @ttm: Pointer to a struct ttm_tt.
> -	 *
> -	 * Destroy the backend. This will be call back from ttm_tt_destroy so
> -	 * don't call ttm_tt_destroy from the callback or infinite loop.
> -	 */
> -	void (*ttm_tt_destroy)(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> -
> -	/**
> -	 * struct ttm_bo_driver member eviction_valuable
> -	 *
> -	 * @bo: the buffer object to be evicted
> -	 * @place: placement we need room for
> -	 *
> -	 * Check with the driver if it is valuable to evict a BO to make room
> -	 * for a certain placement.
> -	 */
> -	bool (*eviction_valuable)(struct ttm_buffer_object *bo,
> -				  const struct ttm_place *place);
> -	/**
> -	 * struct ttm_bo_driver member evict_flags:
> -	 *
> -	 * @bo: the buffer object to be evicted
> -	 *
> -	 * Return the bo flags for a buffer which is not mapped to the hardware.
> -	 * These will be placed in proposed_flags so that when the move is
> -	 * finished, they'll end up in bo->mem.flags
> -	 * This should not cause multihop evictions, and the core will warn
> -	 * if one is proposed.
> -	 */
> -
> -	void (*evict_flags)(struct ttm_buffer_object *bo,
> -			    struct ttm_placement *placement);
> -
> -	/**
> -	 * struct ttm_bo_driver member move:
> -	 *
> -	 * @bo: the buffer to move
> -	 * @evict: whether this motion is evicting the buffer from
> -	 * the graphics address space
> -	 * @ctx: context for this move with parameters
> -	 * @new_mem: the new memory region receiving the buffer
> -	 @ @hop: placement for driver directed intermediate hop
> -	 *
> -	 * Move a buffer between two memory regions.
> -	 * Returns errno -EMULTIHOP if driver requests a hop
> -	 */
> -	int (*move)(struct ttm_buffer_object *bo, bool evict,
> -		    struct ttm_operation_ctx *ctx,
> -		    struct ttm_resource *new_mem,
> -		    struct ttm_place *hop);
> -
> -	/**
> -	 * struct ttm_bo_driver_member verify_access
> -	 *
> -	 * @bo: Pointer to a buffer object.
> -	 * @filp: Pointer to a struct file trying to access the object.
> -	 *
> -	 * Called from the map / write / read methods to verify that the
> -	 * caller is permitted to access the buffer object.
> -	 * This member may be set to NULL, which will refuse this kind of
> -	 * access for all buffer objects.
> -	 * This function should return 0 if access is granted, -EPERM otherwise.
> -	 */
> -	int (*verify_access)(struct ttm_buffer_object *bo,
> -			     struct file *filp);
> -
> -	/**
> -	 * Hook to notify driver about a resource delete.
> -	 */
> -	void (*delete_mem_notify)(struct ttm_buffer_object *bo);
> -
> -	/**
> -	 * notify the driver that we're about to swap out this bo
> -	 */
> -	void (*swap_notify)(struct ttm_buffer_object *bo);
> -
> -	/**
> -	 * Driver callback on when mapping io memory (for bo_move_memcpy
> -	 * for instance). TTM will take care to call io_mem_free whenever
> -	 * the mapping is not use anymore. io_mem_reserve & io_mem_free
> -	 * are balanced.
> -	 */
> -	int (*io_mem_reserve)(struct ttm_bo_device *bdev,
> -			      struct ttm_resource *mem);
> -	void (*io_mem_free)(struct ttm_bo_device *bdev,
> -			    struct ttm_resource *mem);
> -
> -	/**
> -	 * Return the pfn for a given page_offset inside the BO.
> -	 *
> -	 * @bo: the BO to look up the pfn for
> -	 * @page_offset: the offset to look up
> -	 */
> -	unsigned long (*io_mem_pfn)(struct ttm_buffer_object *bo,
> -				    unsigned long page_offset);
> -
> -	/**
> -	 * Read/write memory buffers for ptrace access
> -	 *
> -	 * @bo: the BO to access
> -	 * @offset: the offset from the start of the BO
> -	 * @buf: pointer to source/destination buffer
> -	 * @len: number of bytes to copy
> -	 * @write: whether to read (0) from or write (non-0) to BO
> -	 *
> -	 * If successful, this function should return the number of
> -	 * bytes copied, -EIO otherwise. If the number of bytes
> -	 * returned is < len, the function may be called again with
> -	 * the remainder of the buffer to copy.
> -	 */
> -	int (*access_memory)(struct ttm_buffer_object *bo, unsigned long offset,
> -			     void *buf, int len, int write);
> -
> -	/**
> -	 * struct ttm_bo_driver member del_from_lru_notify
> -	 *
> -	 * @bo: the buffer object deleted from lru
> -	 *
> -	 * notify driver that a BO was deleted from LRU.
> -	 */
> -	void (*del_from_lru_notify)(struct ttm_buffer_object *bo);
> -
> -	/**
> -	 * Notify the driver that we're about to release a BO
> -	 *
> -	 * @bo: BO that is about to be released
> -	 *
> -	 * Gives the driver a chance to do any cleanup, including
> -	 * adding fences that may force a delayed delete
> -	 */
> -	void (*release_notify)(struct ttm_buffer_object *bo);
> -};
> -
> -/**
> - * struct ttm_bo_global - Buffer object driver global data.
> - *
> - * @dummy_read_page: Pointer to a dummy page used for mapping requests
> - * of unpopulated pages.
> - * @shrink: A shrink callback object used for buffer object swap.
> - * @device_list_mutex: Mutex protecting the device list.
> - * This mutex is held while traversing the device list for pm options.
> - * @lru_lock: Spinlock protecting the bo subsystem lru lists.
> - * @device_list: List of buffer object devices.
> - * @swap_lru: Lru list of buffer objects used for swapping.
> - */
> -
> -extern struct ttm_bo_global {
> -
> -	/**
> -	 * Constant after init.
> -	 */
> -
> -	struct kobject kobj;
> -	struct page *dummy_read_page;
> -	spinlock_t lru_lock;
> -
> -	/**
> -	 * Protected by ttm_global_mutex.
> -	 */
> -	struct list_head device_list;
> -
> -	/**
> -	 * Protected by the lru_lock.
> -	 */
> -	struct list_head swap_lru[TTM_MAX_BO_PRIORITY];
> -
> -	/**
> -	 * Internal protection.
> -	 */
> -	atomic_t bo_count;
> -} ttm_bo_glob;
> -
> -
> -#define TTM_NUM_MEM_TYPES 8
> -
> -/**
> - * struct ttm_bo_device - Buffer object driver device-specific data.
> - *
> - * @driver: Pointer to a struct ttm_bo_driver struct setup by the driver.
> - * @man: An array of resource_managers.
> - * @vma_manager: Address space manager (pointer)
> - * lru_lock: Spinlock that protects the buffer+device lru lists and
> - * ddestroy lists.
> - * @dev_mapping: A pointer to the struct address_space representing the
> - * device address space.
> - * @wq: Work queue structure for the delayed delete workqueue.
> - *
> - */
> -
> -struct ttm_bo_device {
> -
> -	/*
> -	 * Constant after bo device init / atomic.
> -	 */
> -	struct list_head device_list;
> -	struct ttm_bo_driver *driver;
> -	/*
> -	 * access via ttm_manager_type.
> -	 */
> -	struct ttm_resource_manager sysman;
> -	struct ttm_resource_manager *man_drv[TTM_NUM_MEM_TYPES];
> -	/*
> -	 * Protected by internal locks.
> -	 */
> -	struct drm_vma_offset_manager *vma_manager;
> -	struct ttm_pool pool;
> -
> -	/*
> -	 * Protected by the global:lru lock.
> -	 */
> -	struct list_head ddestroy;
> -
> -	/*
> -	 * Protected by load / firstopen / lastclose /unload sync.
> -	 */
> -
> -	struct address_space *dev_mapping;
> -
> -	/*
> -	 * Internal protection.
> -	 */
> -
> -	struct delayed_work wq;
> -};
> -
> -static inline struct ttm_resource_manager *ttm_manager_type(struct ttm_bo_device *bdev,
> -							    int mem_type)
> -{
> -	return bdev->man_drv[mem_type];
> -}
> -
> -static inline void ttm_set_driver_manager(struct ttm_bo_device *bdev,
> -					  int type,
> -					  struct ttm_resource_manager *manager)
> -{
> -	bdev->man_drv[type] = manager;
> -}
> -
>  /**
>   * struct ttm_lru_bulk_move_pos
>   *
> @@ -388,31 +101,6 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
>  		     struct ttm_resource *mem,
>  		     struct ttm_operation_ctx *ctx);
>  
> -int ttm_bo_device_release(struct ttm_bo_device *bdev);
> -
> -/**
> - * ttm_bo_device_init
> - *
> - * @bdev: A pointer to a struct ttm_bo_device to initialize.
> - * @glob: A pointer to an initialized struct ttm_bo_global.
> - * @driver: A pointer to a struct ttm_bo_driver set up by the caller.
> - * @dev: The core kernel device pointer for DMA mappings and allocations.
> - * @mapping: The address space to use for this bo.
> - * @vma_manager: A pointer to a vma manager.
> - * @use_dma_alloc: If coherent DMA allocation API should be used.
> - * @use_dma32: If we should use GFP_DMA32 for device memory allocations.
> - *
> - * Initializes a struct ttm_bo_device:
> - * Returns:
> - * !0: Failure.
> - */
> -int ttm_bo_device_init(struct ttm_bo_device *bdev,
> -		       struct ttm_bo_driver *driver,
> -		       struct device *dev,
> -		       struct address_space *mapping,
> -		       struct drm_vma_offset_manager *vma_manager,
> -		       bool use_dma_alloc, bool use_dma32);
> -
>  /**
>   * ttm_bo_unmap_virtual
>   *
> @@ -494,9 +182,9 @@ static inline int ttm_bo_reserve_slowpath(struct ttm_buffer_object *bo,
>  static inline void
>  ttm_bo_move_to_lru_tail_unlocked(struct ttm_buffer_object *bo)
>  {
> -	spin_lock(&ttm_bo_glob.lru_lock);
> +	spin_lock(&ttm_glob.lru_lock);
>  	ttm_bo_move_to_lru_tail(bo, &bo->mem, NULL);
> -	spin_unlock(&ttm_bo_glob.lru_lock);
> +	spin_unlock(&ttm_glob.lru_lock);
>  }
>  
>  static inline void ttm_bo_assign_mem(struct ttm_buffer_object *bo,
> @@ -538,9 +226,9 @@ static inline void ttm_bo_unreserve(struct ttm_buffer_object *bo)
>  /*
>   * ttm_bo_util.c
>   */
> -int ttm_mem_io_reserve(struct ttm_bo_device *bdev,
> +int ttm_mem_io_reserve(struct ttm_device *bdev,
>  		       struct ttm_resource *mem);
> -void ttm_mem_io_free(struct ttm_bo_device *bdev,
> +void ttm_mem_io_free(struct ttm_device *bdev,
>  		     struct ttm_resource *mem);
>  
>  /**
> @@ -631,7 +319,7 @@ void ttm_bo_tt_destroy(struct ttm_buffer_object *bo);
>   * Initialise a generic range manager for the selected memory type.
>   * The range manager is installed for this device in the type slot.
>   */
> -int ttm_range_man_init(struct ttm_bo_device *bdev,
> +int ttm_range_man_init(struct ttm_device *bdev,
>  		       unsigned type, bool use_tt,
>  		       unsigned long p_size);
>  
> @@ -643,7 +331,7 @@ int ttm_range_man_init(struct ttm_bo_device *bdev,
>   *
>   * Remove the generic range manager from a slot and tear it down.
>   */
> -int ttm_range_man_fini(struct ttm_bo_device *bdev,
> +int ttm_range_man_fini(struct ttm_device *bdev,
>  		       unsigned type);
>  
>  #endif
> diff --git a/include/drm/ttm/ttm_device.h b/include/drm/ttm/ttm_device.h
> new file mode 100644
> index 000000000000..7bc8bb797161
> --- /dev/null
> +++ b/include/drm/ttm/ttm_device.h
> @@ -0,0 +1,319 @@
> +/*
> + * Copyright 2020 Advanced Micro Devices, Inc.
> + *
> + * Permission is hereby granted, free of charge, to any person obtaining a
> + * copy of this software and associated documentation files (the "Software"),
> + * to deal in the Software without restriction, including without limitation
> + * the rights to use, copy, modify, merge, publish, distribute, sublicense,
> + * and/or sell copies of the Software, and to permit persons to whom the
> + * Software is furnished to do so, subject to the following conditions:
> + *
> + * The above copyright notice and this permission notice shall be included in
> + * all copies or substantial portions of the Software.
> + *
> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
> + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
> + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
> + * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
> + * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
> + * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
> + * OTHER DEALINGS IN THE SOFTWARE.
> + *
> + * Authors: Christian König
> + */
> +
> +#ifndef _TTM_DEVICE_H_
> +#define _TTM_DEVICE_H_
> +
> +#include <linux/types.h>
> +#include <linux/workqueue.h>
> +#include <drm/ttm/ttm_resource.h>
> +#include <drm/ttm/ttm_pool.h>
> +
> +#define TTM_NUM_MEM_TYPES 8
> +
> +struct ttm_device;
> +struct ttm_placement;
> +struct ttm_buffer_object;
> +struct ttm_operation_ctx;
> +
> +/**
> + * struct ttm_global - Buffer object driver global data.
> + *
> + * @dummy_read_page: Pointer to a dummy page used for mapping requests
> + * of unpopulated pages.
> + * @shrink: A shrink callback object used for buffer object swap.
> + * @device_list_mutex: Mutex protecting the device list.
> + * This mutex is held while traversing the device list for pm options.
> + * @lru_lock: Spinlock protecting the bo subsystem lru lists.
> + * @device_list: List of buffer object devices.
> + * @swap_lru: Lru list of buffer objects used for swapping.
> + */
> +extern struct ttm_global {
> +
> +	/**
> +	 * Constant after init.
> +	 */
> +
> +	struct kobject kobj;
> +	struct page *dummy_read_page;
> +	spinlock_t lru_lock;
> +
> +	/**
> +	 * Protected by ttm_global_mutex.
> +	 */
> +	struct list_head device_list;
> +
> +	/**
> +	 * Protected by the lru_lock.
> +	 */
> +	struct list_head swap_lru[TTM_MAX_BO_PRIORITY];
> +
> +	/**
> +	 * Internal protection.
> +	 */
> +	atomic_t bo_count;
> +} ttm_glob;
> +
> +struct ttm_device_funcs {
> +	/**
> +	 * ttm_tt_create
> +	 *
> +	 * @bo: The buffer object to create the ttm for.
> +	 * @page_flags: Page flags as identified by TTM_PAGE_FLAG_XX flags.
> +	 *
> +	 * Create a struct ttm_tt to back data with system memory pages.
> +	 * No pages are actually allocated.
> +	 * Returns:
> +	 * NULL: Out of memory.
> +	 */
> +	struct ttm_tt *(*ttm_tt_create)(struct ttm_buffer_object *bo,
> +					uint32_t page_flags);
> +
> +	/**
> +	 * ttm_tt_populate
> +	 *
> +	 * @ttm: The struct ttm_tt to contain the backing pages.
> +	 *
> +	 * Allocate all backing pages
> +	 * Returns:
> +	 * -ENOMEM: Out of memory.
> +	 */
> +	int (*ttm_tt_populate)(struct ttm_device *bdev,
> +			       struct ttm_tt *ttm,
> +			       struct ttm_operation_ctx *ctx);
> +
> +	/**
> +	 * ttm_tt_unpopulate
> +	 *
> +	 * @ttm: The struct ttm_tt to contain the backing pages.
> +	 *
> +	 * Free all backing page
> +	 */
> +	void (*ttm_tt_unpopulate)(struct ttm_device *bdev,
> +				  struct ttm_tt *ttm);
> +
> +	/**
> +	 * ttm_tt_destroy
> +	 *
> +	 * @bdev: Pointer to a ttm device
> +	 * @ttm: Pointer to a struct ttm_tt.
> +	 *
> +	 * Destroy the backend. This will be call back from ttm_tt_destroy so
> +	 * don't call ttm_tt_destroy from the callback or infinite loop.
> +	 */
> +	void (*ttm_tt_destroy)(struct ttm_device *bdev, struct ttm_tt *ttm);
> +
> +	/**
> +	 * struct ttm_bo_driver member eviction_valuable
> +	 *
> +	 * @bo: the buffer object to be evicted
> +	 * @place: placement we need room for
> +	 *
> +	 * Check with the driver if it is valuable to evict a BO to make room
> +	 * for a certain placement.
> +	 */
> +	bool (*eviction_valuable)(struct ttm_buffer_object *bo,
> +				  const struct ttm_place *place);
> +	/**
> +	 * struct ttm_bo_driver member evict_flags:
> +	 *
> +	 * @bo: the buffer object to be evicted
> +	 *
> +	 * Return the bo flags for a buffer which is not mapped to the hardware.
> +	 * These will be placed in proposed_flags so that when the move is
> +	 * finished, they'll end up in bo->mem.flags
> +	 * This should not cause multihop evictions, and the core will warn
> +	 * if one is proposed.
> +	 */
> +
> +	void (*evict_flags)(struct ttm_buffer_object *bo,
> +			    struct ttm_placement *placement);
> +
> +	/**
> +	 * struct ttm_bo_driver member move:
> +	 *
> +	 * @bo: the buffer to move
> +	 * @evict: whether this motion is evicting the buffer from
> +	 * the graphics address space
> +	 * @ctx: context for this move with parameters
> +	 * @new_mem: the new memory region receiving the buffer
> +	 @ @hop: placement for driver directed intermediate hop
> +	 *
> +	 * Move a buffer between two memory regions.
> +	 * Returns errno -EMULTIHOP if driver requests a hop
> +	 */
> +	int (*move)(struct ttm_buffer_object *bo, bool evict,
> +		    struct ttm_operation_ctx *ctx,
> +		    struct ttm_resource *new_mem,
> +		    struct ttm_place *hop);
> +
> +	/**
> +	 * struct ttm_bo_driver_member verify_access
> +	 *
> +	 * @bo: Pointer to a buffer object.
> +	 * @filp: Pointer to a struct file trying to access the object.
> +	 *
> +	 * Called from the map / write / read methods to verify that the
> +	 * caller is permitted to access the buffer object.
> +	 * This member may be set to NULL, which will refuse this kind of
> +	 * access for all buffer objects.
> +	 * This function should return 0 if access is granted, -EPERM otherwise.
> +	 */
> +	int (*verify_access)(struct ttm_buffer_object *bo,
> +			     struct file *filp);
> +
> +	/**
> +	 * Hook to notify driver about a resource delete.
> +	 */
> +	void (*delete_mem_notify)(struct ttm_buffer_object *bo);
> +
> +	/**
> +	 * notify the driver that we're about to swap out this bo
> +	 */
> +	void (*swap_notify)(struct ttm_buffer_object *bo);
> +
> +	/**
> +	 * Driver callback on when mapping io memory (for bo_move_memcpy
> +	 * for instance). TTM will take care to call io_mem_free whenever
> +	 * the mapping is not use anymore. io_mem_reserve & io_mem_free
> +	 * are balanced.
> +	 */
> +	int (*io_mem_reserve)(struct ttm_device *bdev,
> +			      struct ttm_resource *mem);
> +	void (*io_mem_free)(struct ttm_device *bdev,
> +			    struct ttm_resource *mem);
> +
> +	/**
> +	 * Return the pfn for a given page_offset inside the BO.
> +	 *
> +	 * @bo: the BO to look up the pfn for
> +	 * @page_offset: the offset to look up
> +	 */
> +	unsigned long (*io_mem_pfn)(struct ttm_buffer_object *bo,
> +				    unsigned long page_offset);
> +
> +	/**
> +	 * Read/write memory buffers for ptrace access
> +	 *
> +	 * @bo: the BO to access
> +	 * @offset: the offset from the start of the BO
> +	 * @buf: pointer to source/destination buffer
> +	 * @len: number of bytes to copy
> +	 * @write: whether to read (0) from or write (non-0) to BO
> +	 *
> +	 * If successful, this function should return the number of
> +	 * bytes copied, -EIO otherwise. If the number of bytes
> +	 * returned is < len, the function may be called again with
> +	 * the remainder of the buffer to copy.
> +	 */
> +	int (*access_memory)(struct ttm_buffer_object *bo, unsigned long offset,
> +			     void *buf, int len, int write);
> +
> +	/**
> +	 * struct ttm_bo_driver member del_from_lru_notify
> +	 *
> +	 * @bo: the buffer object deleted from lru
> +	 *
> +	 * notify driver that a BO was deleted from LRU.
> +	 */
> +	void (*del_from_lru_notify)(struct ttm_buffer_object *bo);
> +
> +	/**
> +	 * Notify the driver that we're about to release a BO
> +	 *
> +	 * @bo: BO that is about to be released
> +	 *
> +	 * Gives the driver a chance to do any cleanup, including
> +	 * adding fences that may force a delayed delete
> +	 */
> +	void (*release_notify)(struct ttm_buffer_object *bo);
> +};
> +
> +/**
> + * struct ttm_device - Buffer object driver device-specific data.
> + *
> + * @device_list: Our entry in the global device list.
> + * @funcs: Function table for the device.
> + * @sysman: Resource manager for the system domain.
> + * @man_drv: An array of resource_managers.
> + * @vma_manager: Address space manager.
> + * @pool: page pool for the device.
> + * @dev_mapping: A pointer to the struct address_space representing the
> + * device address space.
> + * @wq: Work queue structure for the delayed delete workqueue.
> + */
> +struct ttm_device {
> +	/*
> +	 * Constant after bo device init
> +	 */
> +	struct list_head device_list;
> +	struct ttm_device_funcs *funcs;
> +
> +	/*
> +	 * Access via ttm_manager_type.
> +	 */
> +	struct ttm_resource_manager sysman;
> +	struct ttm_resource_manager *man_drv[TTM_NUM_MEM_TYPES];
> +
> +	/*
> +	 * Protected by internal locks.
> +	 */
> +	struct drm_vma_offset_manager *vma_manager;
> +	struct ttm_pool pool;
> +
> +	/*
> +	 * Protected by the global:lru lock.
> +	 */
> +	struct list_head ddestroy;
> +
> +	/*
> +	 * Protected by load / firstopen / lastclose /unload sync.
> +	 */
> +	struct address_space *dev_mapping;
> +
> +	/*
> +	 * Internal protection.
> +	 */
> +	struct delayed_work wq;
> +};
> +
> +static inline struct ttm_resource_manager *
> +ttm_manager_type(struct ttm_device *bdev, int mem_type)
> +{
> +	return bdev->man_drv[mem_type];
> +}
> +
> +static inline void ttm_set_driver_manager(struct ttm_device *bdev, int type,
> +					  struct ttm_resource_manager *manager)
> +{
> +	bdev->man_drv[type] = manager;
> +}
> +
> +int ttm_device_init(struct ttm_device *bdev, struct ttm_device_funcs *funcs,
> +		    struct device *dev, struct address_space *mapping,
> +		    struct drm_vma_offset_manager *vma_manager,
> +		    bool use_dma_alloc, bool use_dma32);
> +void ttm_device_fini(struct ttm_device *bdev);
> +
> +#endif
> diff --git a/include/drm/ttm/ttm_resource.h b/include/drm/ttm/ttm_resource.h
> index da0ed7e8c915..6164ccf4f308 100644
> --- a/include/drm/ttm/ttm_resource.h
> +++ b/include/drm/ttm/ttm_resource.h
> @@ -33,7 +33,7 @@
>  
>  #define TTM_MAX_BO_PRIORITY	4U
>  
> -struct ttm_bo_device;
> +struct ttm_device;
>  struct ttm_resource_manager;
>  struct ttm_resource;
>  struct ttm_place;
> @@ -233,7 +233,7 @@ void ttm_resource_free(struct ttm_buffer_object *bo, struct ttm_resource *res);
>  void ttm_resource_manager_init(struct ttm_resource_manager *man,
>  			       unsigned long p_size);
>  
> -int ttm_resource_manager_evict_all(struct ttm_bo_device *bdev,
> +int ttm_resource_manager_evict_all(struct ttm_device *bdev,
>  				   struct ttm_resource_manager *man);
>  
>  void ttm_resource_manager_debug(struct ttm_resource_manager *man,
> diff --git a/include/drm/ttm/ttm_tt.h b/include/drm/ttm/ttm_tt.h
> index 6c8eb9a4de81..0020a0588985 100644
> --- a/include/drm/ttm/ttm_tt.h
> +++ b/include/drm/ttm/ttm_tt.h
> @@ -118,14 +118,14 @@ void ttm_tt_fini(struct ttm_tt *ttm);
>   *
>   * Unbind, unpopulate and destroy common struct ttm_tt.
>   */
> -void ttm_tt_destroy(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +void ttm_tt_destroy(struct ttm_device *bdev, struct ttm_tt *ttm);
>  
>  /**
>   * ttm_tt_destroy_common:
>   *
>   * Called from driver to destroy common path.
>   */
> -void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +void ttm_tt_destroy_common(struct ttm_device *bdev, struct ttm_tt *ttm);
>  
>  /**
>   * ttm_tt_swapin:
> @@ -135,7 +135,7 @@ void ttm_tt_destroy_common(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>   * Swap in a previously swap out ttm_tt.
>   */
>  int ttm_tt_swapin(struct ttm_tt *ttm);
> -int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +int ttm_tt_swapout(struct ttm_device *bdev, struct ttm_tt *ttm);
>  
>  /**
>   * ttm_tt_populate - allocate pages for a ttm
> @@ -144,7 +144,7 @@ int ttm_tt_swapout(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
>   *
>   * Calls the driver method to allocate pages for a ttm
>   */
> -int ttm_tt_populate(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_operation_ctx *ctx);
> +int ttm_tt_populate(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_operation_ctx *ctx);
>  
>  /**
>   * ttm_tt_unpopulate - free pages from a ttm
> @@ -153,7 +153,7 @@ int ttm_tt_populate(struct ttm_bo_device *bdev, struct ttm_tt *ttm, struct ttm_o
>   *
>   * Calls the driver method to free all pages from a ttm
>   */
> -void ttm_tt_unpopulate(struct ttm_bo_device *bdev, struct ttm_tt *ttm);
> +void ttm_tt_unpopulate(struct ttm_device *bdev, struct ttm_tt *ttm);
>  
>  #if IS_ENABLED(CONFIG_AGP)
>  #include <linux/agp_backend.h>
> -- 
> 2.25.1
> 
> 
_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2021-01-22  8:27 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-01-21 11:58 [PATCH] drm/ttm: device naming cleanup Christian König
2021-01-21 13:39 ` Daniel Vetter
2021-01-21 13:45   ` Christian König
2021-01-22  8:27 ` Huang Rui

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.