提交 d2d51d81 编写于 作者: A Alex Deucher

drm/amdgpu: don't init GDS pool if GDS size is 0 (v2)

SI cards don't expose GDS as a separate pool.  The CP manages
GDS and the UMDs use special CP packets to allocate GDS memory.

v2: drop extra whitespace change

bug: https://bugzilla.kernel.org/show_bug.cgi?id=194867Reviewed-by: NChristian König <christian.koenig@amd.com>
Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
上级 11ba13e1
...@@ -1158,27 +1158,33 @@ int amdgpu_ttm_init(struct amdgpu_device *adev) ...@@ -1158,27 +1158,33 @@ int amdgpu_ttm_init(struct amdgpu_device *adev)
adev->gds.oa.gfx_partition_size = adev->gds.oa.gfx_partition_size << AMDGPU_OA_SHIFT; adev->gds.oa.gfx_partition_size = adev->gds.oa.gfx_partition_size << AMDGPU_OA_SHIFT;
adev->gds.oa.cs_partition_size = adev->gds.oa.cs_partition_size << AMDGPU_OA_SHIFT; adev->gds.oa.cs_partition_size = adev->gds.oa.cs_partition_size << AMDGPU_OA_SHIFT;
/* GDS Memory */ /* GDS Memory */
r = ttm_bo_init_mm(&adev->mman.bdev, AMDGPU_PL_GDS, if (adev->gds.mem.total_size) {
adev->gds.mem.total_size >> PAGE_SHIFT); r = ttm_bo_init_mm(&adev->mman.bdev, AMDGPU_PL_GDS,
if (r) { adev->gds.mem.total_size >> PAGE_SHIFT);
DRM_ERROR("Failed initializing GDS heap.\n"); if (r) {
return r; DRM_ERROR("Failed initializing GDS heap.\n");
return r;
}
} }
/* GWS */ /* GWS */
r = ttm_bo_init_mm(&adev->mman.bdev, AMDGPU_PL_GWS, if (adev->gds.gws.total_size) {
adev->gds.gws.total_size >> PAGE_SHIFT); r = ttm_bo_init_mm(&adev->mman.bdev, AMDGPU_PL_GWS,
if (r) { adev->gds.gws.total_size >> PAGE_SHIFT);
DRM_ERROR("Failed initializing gws heap.\n"); if (r) {
return r; DRM_ERROR("Failed initializing gws heap.\n");
return r;
}
} }
/* OA */ /* OA */
r = ttm_bo_init_mm(&adev->mman.bdev, AMDGPU_PL_OA, if (adev->gds.oa.total_size) {
adev->gds.oa.total_size >> PAGE_SHIFT); r = ttm_bo_init_mm(&adev->mman.bdev, AMDGPU_PL_OA,
if (r) { adev->gds.oa.total_size >> PAGE_SHIFT);
DRM_ERROR("Failed initializing oa heap.\n"); if (r) {
return r; DRM_ERROR("Failed initializing oa heap.\n");
return r;
}
} }
r = amdgpu_ttm_debugfs_init(adev); r = amdgpu_ttm_debugfs_init(adev);
...@@ -1206,9 +1212,12 @@ void amdgpu_ttm_fini(struct amdgpu_device *adev) ...@@ -1206,9 +1212,12 @@ void amdgpu_ttm_fini(struct amdgpu_device *adev)
} }
ttm_bo_clean_mm(&adev->mman.bdev, TTM_PL_VRAM); ttm_bo_clean_mm(&adev->mman.bdev, TTM_PL_VRAM);
ttm_bo_clean_mm(&adev->mman.bdev, TTM_PL_TT); ttm_bo_clean_mm(&adev->mman.bdev, TTM_PL_TT);
ttm_bo_clean_mm(&adev->mman.bdev, AMDGPU_PL_GDS); if (adev->gds.mem.total_size)
ttm_bo_clean_mm(&adev->mman.bdev, AMDGPU_PL_GWS); ttm_bo_clean_mm(&adev->mman.bdev, AMDGPU_PL_GDS);
ttm_bo_clean_mm(&adev->mman.bdev, AMDGPU_PL_OA); if (adev->gds.gws.total_size)
ttm_bo_clean_mm(&adev->mman.bdev, AMDGPU_PL_GWS);
if (adev->gds.oa.total_size)
ttm_bo_clean_mm(&adev->mman.bdev, AMDGPU_PL_OA);
ttm_bo_device_release(&adev->mman.bdev); ttm_bo_device_release(&adev->mman.bdev);
amdgpu_gart_fini(adev); amdgpu_gart_fini(adev);
amdgpu_ttm_global_fini(adev); amdgpu_ttm_global_fini(adev);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册