提交 a751612d 编写于 作者: D Dave Airlie

drm/ttm: drop list of memory managers from device. (v2)

The driver now controls these, the core just controls the system
memory one.

v2: init sysman explicitly and assign it as a driver manager
to simplify the lookup sequence.
Reviewed-by: NChristian König <christian.koenig@amd.com>
Reviewed-by: NBen Skeggs <bskeggs@redhat.com>
Signed-off-by: NDave Airlie <airlied@redhat.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20200804025632.3868079-55-airlied@gmail.com
上级 7541ce1a
...@@ -1556,6 +1556,7 @@ int ttm_bo_device_release(struct ttm_bo_device *bdev) ...@@ -1556,6 +1556,7 @@ int ttm_bo_device_release(struct ttm_bo_device *bdev)
man = ttm_manager_type(bdev, TTM_PL_SYSTEM); man = ttm_manager_type(bdev, TTM_PL_SYSTEM);
ttm_mem_type_manager_disable(man); ttm_mem_type_manager_disable(man);
ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, NULL);
mutex_lock(&ttm_global_mutex); mutex_lock(&ttm_global_mutex);
list_del(&bdev->device_list); list_del(&bdev->device_list);
...@@ -1581,7 +1582,7 @@ EXPORT_SYMBOL(ttm_bo_device_release); ...@@ -1581,7 +1582,7 @@ EXPORT_SYMBOL(ttm_bo_device_release);
static void ttm_bo_init_sysman(struct ttm_bo_device *bdev) static void ttm_bo_init_sysman(struct ttm_bo_device *bdev)
{ {
struct ttm_mem_type_manager *man = ttm_manager_type(bdev, TTM_PL_SYSTEM); struct ttm_mem_type_manager *man = &bdev->sysman;
/* /*
* Initialize the system memory buffer type. * Initialize the system memory buffer type.
...@@ -1592,6 +1593,7 @@ static void ttm_bo_init_sysman(struct ttm_bo_device *bdev) ...@@ -1592,6 +1593,7 @@ static void ttm_bo_init_sysman(struct ttm_bo_device *bdev)
man->default_caching = TTM_PL_FLAG_CACHED; man->default_caching = TTM_PL_FLAG_CACHED;
ttm_mem_type_manager_init(man, 0); ttm_mem_type_manager_init(man, 0);
ttm_set_driver_manager(bdev, TTM_PL_SYSTEM, man);
ttm_mem_type_manager_set_used(man, true); ttm_mem_type_manager_set_used(man, true);
} }
...@@ -1613,8 +1615,6 @@ int ttm_bo_device_init(struct ttm_bo_device *bdev, ...@@ -1613,8 +1615,6 @@ int ttm_bo_device_init(struct ttm_bo_device *bdev,
bdev->driver = driver; bdev->driver = driver;
memset(bdev->man_priv, 0, sizeof(bdev->man_priv));
ttm_bo_init_sysman(bdev); ttm_bo_init_sysman(bdev);
bdev->vma_manager = vma_manager; bdev->vma_manager = vma_manager;
......
...@@ -414,7 +414,7 @@ struct ttm_bo_device { ...@@ -414,7 +414,7 @@ struct ttm_bo_device {
/* /*
* access via ttm_manager_type. * access via ttm_manager_type.
*/ */
struct ttm_mem_type_manager man_priv[TTM_NUM_MEM_TYPES]; struct ttm_mem_type_manager sysman;
struct ttm_mem_type_manager *man_drv[TTM_NUM_MEM_TYPES]; struct ttm_mem_type_manager *man_drv[TTM_NUM_MEM_TYPES];
/* /*
* Protected by internal locks. * Protected by internal locks.
...@@ -446,9 +446,7 @@ struct ttm_bo_device { ...@@ -446,9 +446,7 @@ struct ttm_bo_device {
static inline struct ttm_mem_type_manager *ttm_manager_type(struct ttm_bo_device *bdev, static inline struct ttm_mem_type_manager *ttm_manager_type(struct ttm_bo_device *bdev,
int mem_type) int mem_type)
{ {
if (bdev->man_drv[mem_type]) return bdev->man_drv[mem_type];
return bdev->man_drv[mem_type];
return &bdev->man_priv[mem_type];
} }
static inline void ttm_set_driver_manager(struct ttm_bo_device *bdev, static inline void ttm_set_driver_manager(struct ttm_bo_device *bdev,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册